根据我在哪台计算机上运行,此代码将获得不同的缩放比例。
Metafile image;
IntPtr dib;
var memoryHdc = Win32Utils.CreateMemoryHdc(IntPtr.Zero, 1, 1, out dib);
try
{
image = new Metafile(memoryHdc, EmfType.EmfOnly);
using (var g = Graphics.FromImage(image))
{
Render(g, html, left, top, maxWidth, cssData, stylesheetLoad, imageLoad);
}
}
finally
{
Win32Utils.ReleaseMemoryHdc(memoryHdc, dib);
}
进入Render方法后,图元文件对象的像素格式为DontCare,因此没有有效的垂直或水平分辨率。
来自“渲染”方法,其值为Format32bppRgb
,并且PhysicalDimension.Width
和PhysicalDimension.Height
已增加以适应渲染的图像。
如何使缩放比例独立于本地设置?
这是CreateMemoryHdc
的实现(我没有写,它来自OSS库)。
public static IntPtr CreateMemoryHdc(IntPtr hdc, int width, int height, out IntPtr dib)
{
// Create a memory DC so we can work off-screen
IntPtr memoryHdc = CreateCompatibleDC(hdc);
SetBkMode(memoryHdc, 1);
// Create a device-independent bitmap and select it into our DC
var info = new BitMapInfo();
info.biSize = Marshal.SizeOf(info);
info.biWidth = width;
info.biHeight = -height;
info.biPlanes = 1;
info.biBitCount = 32;
info.biCompression = 0; // BI_RGB
IntPtr ppvBits;
dib = CreateDIBSection(hdc, ref info, 0, out ppvBits, IntPtr.Zero, 0);
SelectObject(memoryHdc, dib);
return memoryHdc;
}
如您所见,传递给DC构造函数的宽度,高度和位深度是恒定的。创建图元文件会产生不同的物理尺寸。执行完之后
image = new Metafile(memoryHdc, EmfType.EmfOnly);
图元文件的PhysicalDimension.Height
(和宽度)在我的工作站上为26.43,在我要部署到的服务器上为31.25,因此缩放上的差异已经很明显,因此可能不是渲染中的任何结果
这可能是相关的。 BitMapInfo
在OSS库中定义,如下所示:
internal struct BitMapInfo
{
public int biSize;
public int biWidth;
public int biHeight;
public short biPlanes;
public short biBitCount;
public int biCompression;
public int biSizeImage;
public int biXPelsPerMeter;
public int biYPelsPerMeter;
public int biClrUsed;
public int biClrImportant;
public byte bmiColors_rgbBlue;
public byte bmiColors_rgbGreen;
public byte bmiColors_rgbRed;
public byte bmiColors_rgbReserved;
}
因此可以设置biXPelsPerMeter
和biYPelsPerMeter
会有所帮助。上面的代码没有设置它们,并且可能允许平台值。
不幸的是,设置这些值似乎没有什么区别。 msdn说
biXPelsPerMeter
像素的水平分辨率(以每米像素为单位) 位图的目标设备。应用程序可以使用该值来 从资源组中选择最匹配的位图 当前设备的特征。
因此,当从资源中加载位图时,将使用这些设置。这里没有帮助。
了解此代码未在应用程序中运行可能会有所帮助。它将HTML呈现为用于打印的图元文件,并且位于Web API网络服务中。
没有用户界面,所以我不确定如何解释它是否为DPI Aware问题。证据表明它是DPI 受影响的,因此该问题可能是相关的。
答案 0 :(得分:0)
GDI无法缩放。使用GDI +来实现设备独立性。您将失去抗锯齿功能,但是大多数打印设备的DPI仍然很高。
正在使用的库是否可以选择使用GDI +?
(我个人是的,问题已解决。)