欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

WPF中圖像處理的方法介紹

 更新時間:2022年06月17日 09:07:29   作者:天方  
這篇文章介紹了WPF中圖像處理的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

和Winform中的GDI+相比,WPF提供了一組新的API用于顯示和編輯圖像。新API特點如下:

  • 適用于新的或?qū)S脠D像格式的擴展性模型。

  • 對包括位圖 (BMP)、聯(lián)合圖像專家組 (JPEG)、可移植網(wǎng)絡(luò)圖形 (PNG)、標記圖像文件格式 (TIFF)、Microsoft Windows Media 照片、圖形交換格式 (GIF) 和圖標 (.ico) 在內(nèi)的本機圖像格式增強了性能和安全性。

  • 高位深圖像數(shù)據(jù)的保留最多 32 位/通道。

  • 非破壞性圖像縮放、裁切和旋轉(zhuǎn)。

  • 簡化的顏色管理

  • 支持文件內(nèi)的專用元數(shù)據(jù)。

  • 托管組件利用非托管基礎(chǔ)結(jié)構(gòu)提供圖像與其他 WPF 功能(如用戶界面 (UI)、動畫和圖形)的無縫集成。托管組件還可以從 Windows Presentation Foundation (WPF) 圖像處理編解碼器擴展性模型獲益,利用該模型可以實現(xiàn)自動識別 WPF 中的新圖像格式。

大部分托管的 WPF 圖像處理 API 駐留在 System.Windows.Media.Imaging 命名空間中,不過,幾個重要的類型(如 ImageBrush 和 ImageDrawing)都駐留在 System.Windows.Media 命名空間,Image 駐留在 System.Windows.Controls 命名空間。

下面我通過一個簡單的示例演示一下新的API的使用方法:

圖像編碼格式轉(zhuǎn)換:

var imageStreamSource = File.OpenRead(@"r:\1\24.bmp");
var decoder = BitmapDecoder.Create(imageStreamSource, BitmapCreateOptions.PreservePixelFormat, BitmapCacheOption.Default);
var bitmapFrame = decoder.Frames[0];

//在界面上顯示圖片
//image1.Source = bitmapFrame;

var encoder = new JpegBitmapEncoder();
encoder.Frames.Add(bitmapFrame);
encoder.Save(File.Create(@"r:\1\3.jpg"));

這個功能非常簡單,就是把一個bmp格式的圖片轉(zhuǎn)換為了一個jpg格式的圖片。這個示例也顯示了WPF的圖像處理的基本方式:

  • 從解碼器(xxxDecoder)中獲取圖像信息
    創(chuàng)建解碼器后,圖像信息就保存在Frames(雖然大部分圖像(jpg,bmp,png等)只有一幀,但GIF,ico等圖像有多幀)屬性中了。

  • 用編碼器(xxxEncoder)保持圖像信息
    相應(yīng)的,編碼時只要創(chuàng)建編碼器,并設(shè)置相應(yīng)的幀即可。

圖像處理:

常用的圖像處理包括縮放、裁切和旋轉(zhuǎn)等,如下是一個將圖像旋轉(zhuǎn)90度的例子。

var imageStreamSource = File.OpenRead(@"r:\1\24.bmp");
var decoder = BitmapDecoder.Create(imageStreamSource, BitmapCreateOptions.PreservePixelFormat, BitmapCacheOption.Default);
var bitmapFrame = decoder.Frames[0];  

TransformedBitmap myRotatedBitmapSource = new TransformedBitmap();
myRotatedBitmapSource.BeginInit();
myRotatedBitmapSource.Source = bitmapFrame;  

// 旋轉(zhuǎn)90度
myRotatedBitmapSource.Transform = new RotateTransform(90);
myRotatedBitmapSource.EndInit(); 

//旋轉(zhuǎn)

var rotate = new RotateTransform(90);
var rotatedBitMap = new TransformedBitmap(bitmapFrame, rotate);

image1.Source = rotatedBitMap;

////裁剪
//CroppedBitmap chainedBitMap = new CroppedBitmap(bitmapFrame,new Int32Rect(100, 0, (int)bitmapFrame.Width - 100, (int)bitmapFrame.Height));

////縮放
//var scare = new ScaleTransform(1.5, 2);
//var scaredBitMap = new TransformedBitmap(bitmapFrame, scare);

var encoder = new JpegBitmapEncoder();
encoder.Frames.Add(BitmapFrame.Create(rotatedBitMap));
//encoder.Frames.Add(BitmapFrame.Create(scaredBitMap));
//encoder.Frames.Add(BitmapFrame.Create(chainedBitMap));
encoder.Save(File.Create(@"r:\1\3.jpg"));

和上面的例子相比,這里就是多了一個TransformedBitmap變換,其實這和xaml中的變換時一樣的。

<Image Width="150" Margin="5" Grid.Column="0" Grid.Row="1">
  <Image.Source>
    <TransformedBitmap Source="/sampleImages/watermelon.jpg" >
      <TransformedBitmap.Transform>
        <RotateTransform Angle="90"/>
      </TransformedBitmap.Transform>
    </TransformedBitmap>
  </Image.Source>
</Image>

其它變換也都可以參照xaml中處理方式進行,這里就不過多介紹了。

到此這篇關(guān)于WPF圖像處理的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論