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);
}
相关推荐
huizhixue-IT21 小时前
华为存储考试内容&HCIP-Storage
wpf
桂月二二2 天前
实时事件流处理架构的容错设计
架构·wpf
源之缘-OFD先行者2 天前
GMap.NET + WPF:构建高性能 ADS-B 航空器追踪平台
.net·wpf·ads-b
Marzlam2 天前
WPF学习路线
wpf
weixin_535455792 天前
WPF设计学习记录滴滴滴2
学习·wpf
^@^lemon tea^@^2 天前
WPF 浅述IsHitTestVisible属性
wpf·wpf 穿透
lixy5792 天前
C# WPF 命令机制(关闭CanExecute自动触发,改手动)
c#·wpf
Marzlam2 天前
一文了解WPF技术简介
wpf
arriettyandray2 天前
C#/WPF学习系列之问题记录——使用不流畅
c#·wpf
勘察加熊人3 天前
wpf+c#路径迷宫鼠标绘制
开发语言·c#·wpf