- [SQLSERVER] Loại bỏ Restricted User trên database MSSQL
- [C#] Hướng dẫn tạo mã QRcode Style trên winform
- [C#] Hướng dẫn sử dụng temp mail service api trên winform
- [C#] Hướng dẫn tạo mã thanh toán VietQR Pay không sử dụng API trên winform
- [C#] Hướng Dẫn Tạo Windows Service Đơn Giản Bằng Topshelf
- [C#] Chia sẻ source code đọc dữ liệu từ Google Sheet trên winform
- [C#] Chia sẻ source code tạo mã QR MOMO đa năng Winform
- [C#] Chia sẻ source code phần mềm lên lịch tự động chạy ứng dụng Scheduler Task Winform
- [Phần mềm] Tải và cài đặt phần mềm Sublime Text 4180 full version
- [C#] Hướng dẫn download file từ Minio Server Winform
- [C#] Hướng dẫn đăng nhập zalo login sử dụng API v4 trên winform
- [SOFTWARE] Phần mềm gởi tin nhắn Zalo Marketing Pro giá rẻ mềm nhất thị trường
- [C#] Việt hóa Text Button trên MessageBox Dialog Winform
- [DEVEXPRESS] Chia sẻ code các tạo report in nhiều hóa đơn trên XtraReport C#
- [POWER AUTOMATE] Hướng dẫn gởi tin nhắn zalo từ file Excel - No code
- [C#] Chia sẻ code lock và unlock user trong domain Window
- [DEVEXPRESS] Vẽ Biểu Đồ Stock Chứng Khoán - Công Cụ Thiết Yếu Cho Nhà Đầu Tư trên Winform
- [C#] Hướng dẫn bảo mật ứng dụng 2FA (Multi-factor Authentication) trên Winform
- [C#] Hướng dẫn convert HTML code sang PDF File trên NetCore 7 Winform
- [C#] Hướng dẫn viết ứng dụng chat với Gemini AI Google Winform
[DEVEXPRESS] Hướng dẫn tải hình ảnh bất đồng bộ (Load Image Async) vào GridView
Xin chào các bạn, bài viết hôm nay mình sẽ tiếp tục hướng dẫn các bạn cách tải hình ảnh bất đồng bộ từ trên server về Grid View Devexpress.
Ví dụ: Các bạn có một danh sách sinh viên khoảng 1000 sinh viên, và có 1000 hình ảnh sinh viên trên server.
Nếu các bạn tải hình ảnh bình thường trên server thì GridView sẽ chờ rất nhiều thời gian mới load xong và hiển thị dữ liệu lên GridView cho các bạn.
Vậy trong bài viết này, mình sẽ hướng dẫn cho các bạn hiển thị các thông tin lên trên gridview trước, còn hình ảnh mình sẽ tải bất đồng bộ sau.
Demo tải hình ảnh bất đồng bộ C#:
Source code Load Image Async to GridView C#:
using DevExpress.Utils;
using DevExpress.XtraEditors.Controls;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
namespace LoadImageAsyncToGridView
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
private void button1_Click(object sender, EventArgs e)
{
BindingList list = new BindingList();
for (int i = 0; i <= 100; i++)
{
list.Add(new PictureObject("windows", @"http://taimienphi.vn/tmp/cf/icon/343-windows-icons.jpg"));
list.Add(new PictureObject("Lap trinh vb.net", @"https://laptrinhvb.net/uploads/baiviet/images/faa3d533876e9cf7332137ca542e0902.jpg"));
list.Add(new PictureObject("Banded Reporting", @"https://laptrinhvb.net/public/images/logo.png"));
}
gridView1.OptionsView.RowAutoHeight = true;
gridView1.OptionsView.AnimationType = DevExpress.XtraGrid.Views.Base.GridAnimationType.AnimateAllContent;
gridControl1.DataSource = list;
list.ListChanged += (s, args) =>
{
if (args.PropertyDescriptor.Name == "Image")
gridView1.LayoutChanged();
};
}
public class PictureObject : INotifyPropertyChanged
{
public string Name { get; set; }
public Image Image { get; set; }
public event PropertyChangedEventHandler PropertyChanged;
public PictureObject(string name, string url)
{
Name = name;
Image = ResourceImageHelper.CreateImageFromResources("DevExpress.XtraEditors.Images.loading.gif", typeof(BackgroundImageLoader).Assembly);
BackgroundImageLoader bg = new BackgroundImageLoader();
bg.Load(url);
bg.Loaded += (s, e) =>
{
Image = bg.Result;
if (!(Image is Image)) Image = ResourceImageHelper.CreateImageFromResources("DevExpress.XtraEditors.Images.Error.png", typeof(BackgroundImageLoader).Assembly);
PropertyChanged(this, new PropertyChangedEventArgs("Image"));
bg.Dispose();
};
}
}
}
}
HAPPY CODING