WPF中RenderTargetBitmap问题解决

位置问题

使用RenderTargetBitmap截取某一可视元素时,很多时候会出现元素并不是在图片左上角的问题。

解决这一问题的方法是,在要截取元素外,再加一个Border。

例如:

cs 复制代码
<Border>
    <Canvas Name="ToRender">
    </Canvas>
</Border>

背景黑色问题

希望背景是其他颜色,只要设置截取元素的背景即可。例如:

cs 复制代码
<Border>
    <Canvas Name="ToRender" Background="White">
    </Canvas>
</Border>

导出尺寸跟实际尺寸不一致问题

使用以下代码解决:

cs 复制代码
var renderBitmap = new RenderTargetBitmap(width, height, 96, 96, PixelFormats.Pbgra32);
var visualBrush = new VisualBrush(ToRender);
var drawingVisual = new DrawingVisual();
using (var drawingContext = drawingVisual.RenderOpen())
{
    drawingContext.DrawRectangle(visualBrush, null, new Rect(0, 0, width, height));
}
renderBitmap.Render(drawingVisual);

var encoder = new JpegBitmapEncoder();
encoder.Frames.Add(BitmapFrame.Create(renderBitmap));
using (var fileStream = new FileStream("result.jpg", FileMode.Create))
{
    encoder.Save(fileStream);
}

分辨率非96问题

显示器中显示图片的分辨率为96。当导出图片的分辨率非这个值时(例如打印一般用dpi300),需要进行调整。

cs 复制代码
var renderBitmap = new RenderTargetBitmap(width, height, dpi, dpi, PixelFormats.Pbgra32);
var visualBrush = new VisualBrush(ToRender);
var drawingVisual = new DrawingVisual();
using (var drawingContext = drawingVisual.RenderOpen())
{
    drawingContext.DrawRectangle(visualBrush, null, new Rect(0, 0, width / dpi * 96, height / dpi * 96));
}
renderBitmap.Render(drawingVisual);

var encoder = new JpegBitmapEncoder();
encoder.Frames.Add(BitmapFrame.Create(renderBitmap));
using (var fileStream = new FileStream("result.jpg", FileMode.Create))
{
    encoder.Save(fileStream);
}
相关推荐
5***a9756 小时前
后端配置中心选型,Nacos与Apollo
wpf
·心猿意码·6 小时前
WPF转换器机制
wpf
她说彩礼65万9 小时前
WPF命令
wpf
玖笙&12 小时前
✨WPF编程进阶【7.3】集成动画(附源码)
c++·c#·wpf·visual studio
ifeng091819 小时前
鸿蒙分布式调试挑战:跨设备数据流转与连接稳定性
分布式·wpf·harmonyos
Macbethad1 天前
如何使用WPF做工控主页
wpf
Aevget1 天前
DevExpress WPF中文教程:Data Grid - Service(服务)示例
wpf·界面控件·devexpress·ui开发
Macbethad2 天前
WPF工控软件的设计方案
wpf
Macbethad4 天前
使用WPF编写一个读取串口的程序
wpf
Macbethad5 天前
如何用WPF做工控设置界面
java·开发语言·wpf