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);
}
相关推荐
c#上位机20 小时前
wpf中Grid的MouseDown 事件无法触发的原因
c#·wpf
△曉風殘月〆20 小时前
如何在WPF中实现ComboBox多选
wpf
csdn_aspnet1 天前
如何使用现有工具进行 .NET 8 迁移 Wpf
wpf·.net 8
123梦野2 天前
WPF——动画
wpf
攻城狮CSU2 天前
WPF 疑点汇总2.HorizontalAlignment和 HorizontalContentAlignment
wpf
c#上位机2 天前
wpf之命令
c#·wpf
没有bug.的程序员2 天前
分布式链路追踪:微服务可观测性的核心支柱
java·分布式·微服务·架构·wpf
Aevget3 天前
DevExpress WPF中文教程:Data Grid - 如何使用虚拟源?(一)
c#·wpf·界面控件·devexpress·ui开发
The Sheep 20234 天前
WPF自定义路由事件
大数据·hadoop·wpf
阳光雨滴4 天前
使用wpf用户控件编程落石效果动画
c++·wpf