Использование элемента управления изображением в WPF для отображения System.Drawing.Bitmap - PullRequest
75 голосов
/ 13 июля 2009

Как назначить объект Bitmap в памяти элементу управления Image в WPF?

Ответы [ 4 ]

86 голосов
/ 13 июля 2009

Согласно http://khason.net/blog/how-to-use-systemdrawingbitmap-hbitmap-in-wpf/

   [DllImport("gdi32")]
   static extern int DeleteObject(IntPtr o);

   public static BitmapSource loadBitmap(System.Drawing.Bitmap source)
   {
       IntPtr ip = source.GetHbitmap();
       BitmapSource bs = null;
       try
       {
           bs = System.Windows.Interop.Imaging.CreateBitmapSourceFromHBitmap(ip, 
              IntPtr.Zero, Int32Rect.Empty, 
              System.Windows.Media.Imaging.BitmapSizeOptions.FromEmptyOptions());
       }
       finally
       {
           DeleteObject(ip);
       }

       return bs;
   }

Он получает System.Drawing.Bitmap (из WindowsBased) и преобразует его в BitmapSource, который может фактически использоваться в качестве источника изображения для элемента управления изображением в WPF.

image1.Source = YourUtilClass.loadBitmap(SomeBitmap);
19 голосов
/ 13 июля 2009

Вы можете использовать свойство Source изображения. Попробуйте этот код ...

ImageSource imageSource = new BitmapImage(new Uri("C:\\FileName.gif"));

image1.Source = imageSource;
16 голосов
/ 26 апреля 2012

Легко для файла на диске, но сложнее для растрового изображения в памяти.

System.Drawing.Bitmap bmp;
Image image;
...
MemoryStream ms = new MemoryStream();
bmp.Save(ms, System.Drawing.Imaging.ImageFormat.Png);
ms.Position = 0;
BitmapImage bi = new BitmapImage();
bi.BeginInit();
bi.StreamSource = ms;
bi.EndInit();

image.Source = bi;

Украдено здесь

2 голосов
/ 13 декабря 2012

Я написал программу с wpf и использовал базу данных для показа изображений, и это мой код:

SqlConnection con = new SqlConnection(@"Data Source=HITMAN-PC\MYSQL;
                                      Initial Catalog=Payam;
                                      Integrated Security=True");

SqlDataAdapter da = new SqlDataAdapter("select * from news", con);

DataTable dt = new DataTable();
da.Fill(dt);

string adress = dt.Rows[i]["ImgLink"].ToString();
ImageSource imgsr = new BitmapImage(new Uri(adress));
PnlImg.Source = imgsr;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...