深入分析WPF客戶端讀取高清圖片卡以及縮略圖的解決方法詳解
更新時間:2013年05月13日 15:06:59 作者:
本篇文章是對WPF客戶端讀取高清圖片卡以及縮略圖的解決方法進行了詳細(xì)的分析介紹,需要的朋友參考下
在Ftp上傳上,有人上傳了高清圖片,每張圖片大約2M。
如果使用傳統(tǒng)的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來生成圖片了。
最后說一句:雖然解決了這個問題,不過每次都要下載高清圖片,生成縮略圖,這是很耗時的,所以在上傳圖片的時候就應(yīng)該生成縮略圖了,將縮略圖保存起來了。因為在局域網(wǎng)中,網(wǎng)速比較快,這種方式基本也可以滿足要求了。
如果使用傳統(tǒng)的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來生成圖片了。
最后說一句:雖然解決了這個問題,不過每次都要下載高清圖片,生成縮略圖,這是很耗時的,所以在上傳圖片的時候就應(yīng)該生成縮略圖了,將縮略圖保存起來了。因為在局域網(wǎng)中,網(wǎng)速比較快,這種方式基本也可以滿足要求了。
相關(guān)文章
DevExpress GridControl實現(xiàn)根據(jù)RowIndex和VisibleColumnsIndex來獲取單元格
這篇文章主要介紹了DevExpress GridControl實現(xiàn)根據(jù)RowIndex和VisibleColumnsIndex來獲取單元格值,需要的朋友可以參考下2014-08-08WinForm中KeyDown,KeyPress和KeyUp的順序與區(qū)別解析
這篇文章主要介紹了WinForm中KeyDown,KeyPress和KeyUp的順序與區(qū)別解析,對C#初學(xué)者來說很有學(xué)習(xí)借鑒價值,需要的朋友可以參考下2014-08-08C#實現(xiàn)遞歸調(diào)用的Lambda表達式
這篇文章介紹了C#實現(xiàn)遞歸調(diào)用的Lambda表達式,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06