将 RenderTargetBitmap 转换为 System.Drawing.Image

将 RenderTargetBitmap 转换为 System.Drawing.Image

问题描述:

我有 3D WPF 视觉效果,我想将其传递到 Excel 单元格中(通过剪贴板缓冲区).

I have 3D WPF visual that I want to pass into an Excel cell (via clipboard buffer).

使用普通"BMP 图像它可以工作,但我不知道如何转换 RenderTargetBitmap.

With "normal" BMP images it works but I do not know how to convert a RenderTargetBitmap.

我的代码如下所示:

System.Windows.Media.Imaging.RenderTargetBitmap renderTarget = myParent.GetViewPortAsImage(DiagramSizeX, DiagramSizeY);
System.Windows.Controls.Image myImage = new System.Windows.Controls.Image();
myImage.Source = renderTarget;

System.Drawing.Bitmap pg = new System.Drawing.Bitmap(DiagramSizeX, DiagramSizeY);
System.Drawing.Graphics gr = System.Drawing.Graphics.FromImage(pg);
gr.DrawImage(myImage, 0, 0);

System.Windows.Forms.Clipboard.SetDataObject(pg, true);
sheet.Paste(range);

我的问题是 gr.DrawImage 不接受 System.Windows.Controls.ImageSystem.Windows.Media.Imaging.RenderTargetBitmap代码>;只有一个System.Drawing.Image.

My problem is that gr.DrawImage does not accept a System.Windows.Controls.Image or a System.Windows.Media.Imaging.RenderTargetBitmap; only a System.Drawing.Image.

如何将Controls.Image.Imaging.RenderTargetBitmap 转换成Image,或者有什么更简单的方法?

How do I convert the Controls.Image.Imaging.RenderTargetBitmap into an Image, or are there any easier ways?

这是我想出的解决方案

System.Windows.Media.Imaging.RenderTargetBitmap renderTarget = myParent.GetViewPortAsImage(DiagramSizeX, DiagramSizeY);
System.Windows.Media.Imaging.BitmapEncoder encoder = new System.Windows.Media.Imaging.PngBitmapEncoder();
MemoryStream myStream = new MemoryStream();

encoder.Frames.Add(System.Windows.Media.Imaging.BitmapFrame.Create(renderTarget));
encoder.Save(myStream);
//
System.Drawing.Bitmap pg = new System.Drawing.Bitmap(DiagramSizeX, DiagramSizeY);
System.Drawing.Graphics gr = System.Drawing.Graphics.FromImage(pg);
//
// Background
//
gr.FillRectangle(new System.Drawing.SolidBrush(BKGC), 0, 0, DiagramSizeX, DiagramSizeY);
//
gr.DrawImage(System.Drawing.Bitmap.FromStream(myStream), 0, 0);
System.Windows.Forms.Clipboard.SetDataObject(pg, true);

sheet.Paste(range);