Search code examples
c#.netwinformspictureboxwebrequest

Asynchronously Load an Image from a Url to a PictureBox


I want to load image from the web on windows forms application, Everything is good and code works fine, but the problem is the app stop working until the loading goes to finish. I want to see and work with app without waiting to loading .

PictureBox img = new System.Windows.Forms.PictureBox();
var request = WebRequest.Create(ThumbnailUrl);

using (var response = request.GetResponse())
using (var stream = response.GetResponseStream())
{
    img.Image = Bitmap.FromStream(stream);
}

Solution

  • Here is the solution:

    public async Task<Image> GetImageAsync(string url)
    {
        var tcs = new TaskCompletionSource<Image>();
        Image webImage = null;
        HttpWebRequest request = (HttpWebRequest) WebRequest.Create(url);
        request.Method = "GET";
        await Task.Factory.FromAsync<WebResponse>(request.BeginGetResponse, request.EndGetResponse, null)
            .ContinueWith(task =>
            {
                var webResponse = (HttpWebResponse) task.Result;
                Stream responseStream = webResponse.GetResponseStream();
                if (webResponse.ContentEncoding.ToLower().Contains("gzip"))
                    responseStream = new GZipStream(responseStream, CompressionMode.Decompress);
                else if (webResponse.ContentEncoding.ToLower().Contains("deflate"))
                    responseStream = new DeflateStream(responseStream, CompressionMode.Decompress);
    
                if (responseStream != null) webImage = Image.FromStream(responseStream);
                tcs.TrySetResult(webImage);
                webResponse.Close();
                responseStream.Close();
            });
        return tcs.Task.Result;
    }
    

    Here is how to call the above solution:

    PictureBox img = new System.Windows.Forms.PictureBox();
    var result = GetImageAsync(ThumbnailUrl);
    result.ContinueWith(task =>
    {
        img.Image = task.Result;
    });