WPF客户端读取高清图片很卡,缩略图解决方案
在Ftp上传上,有人上传了高清图片,每张图片大约2M。
如果使用传统的BitmapImage类,然后绑定 Source 属性的方法,有些电脑在首次会比较卡,一张电脑10秒,4张大约会卡40秒。
所以我先异步的下载图片,得到downloadFileStream对象,然后绑定到BitmapImage类上。例如:
System.Windows.Controls.Image photo = new Image
{
Width = 100,
Height = 100,
Margin = new Thickness(2),
Stretch = Stretch.Uniform
};
BitmapImage bitmap = new BitmapImage();
bitmap.BeginInit();
bitmap.StreamSource = downloadFileStream;
bitmap.EndInit();
photo.Source = bitmap;
ListBoxItem lbi = new ListBoxItem()
{
DataContext = pvo,
Content = photo
};
this.lbPhotoes.Items.Add(lbi);
因为bitmap的StreamSource比较大,造成lbi对象比较大,所以lbPhotoes.Items.Add 方法在添加了两张图片之后就会卡大约30秒的时间。
所以尝试使用缩略图的方式来使BitmapImage的对象变小,在这里采用缩略图是因为客户端需要图片大小大致是
(100,100)。
完整的代码如下:
System.Windows.Controls.Image photo = new Image
{
Width = 100,
Height = 100,
Margin = new Thickness(2),
Stretch = Stretch.Uniform
};
using (System.Drawing.Image drawingImage = System.Drawing.Image.FromStream(downloadFileStream))
{
using (System.Drawing.Image thumbImage =
drawingImage.GetThumbnailImage(100, 100, () => { return true; }, IntPtr.Zero))
{
MemoryStream ms = new MemoryStream();
thumbImage.Save(ms, System.Drawing.Imaging.ImageFormat.Png);
BitmapFrame bf = BitmapFrame.Create(ms);
photo.Source = bf;
}
}
ListBoxItem lbi = new ListBoxItem()
{
DataContext = pvo,
Content = photo
};
this.lbPhotoes.Items.Add(lbi);
在这里,要引用System.Drawing.dll.使用System.Drawing.Image 类的GetThumbnailImage 方法来获取thumbImage,接着使用MemoryStream来保存缩略图的stream,接着用缩略图的stream来生成图片了。
最后说一句:虽然解决了这个问题,不过每次都要下载高清图片,生成缩略图,这是很耗时的,所以在上传图片的时候就应该生成缩略图了,将缩略图保存起来了。因为在局域网中,网速比较快,这种方式基本也可以满足要求了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架