将 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.Image
或 System.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);