6

我正在尝试在网站上创建“将网页另存为位图”功能,但在服务器端以正确大小呈现文本时遇到了一些问题。

客户端上文本的字体大小设置为:

.textDiv
{
    font-family: Verdana;
    font-size:16px;
}

如果我尝试在服务器上渲染它

float emSize = 16;
g.DrawString("mytext", new Font("Verdana", emSize), Brushes.Black, x, y);

服务器上的文本将变大约 20%。

new Font()的文档说第二个参数(字体大小)应该在 em 点中指定。一个 em 点到底是什么?

如果我在浏览器中指定 font-size:16em,文本会变得很大。如果我在浏览器中指定 font-size:1em 文本将大约 14px 大,但如果我将 1 作为服务器上的参数,则文本变成一条细线。

那么,我如何从浏览器 px 或 em 转换为 .net px/em。

4

2 回答 2

4

实际上,文档说“em-size”,而不是“em-point”(“新字体的 em-size,以磅为单位”)。它要求您以磅为单位指定大小。每英寸有 72 个点。您需要计算出用户屏幕的 DPI 和您正在绘制的画布的 DPI,并将 16px 大小乘以该比率的差异。

例如

(CSS_Font_Size_Pixels * Canvas_DPI) / (User_Screen_DPI * 72) = Equivalent_Point_Size

您可以通过使用采用 GraphicUnit 并指定像素的 Font 构造函数重载来节省数学运算。这样,适当的大小将是:

(CSS_Font_Size_Pixels  / User_Screen_DPI) * Canvas_DPI
于 2009-01-27T20:21:18.173 回答
0

我有点困惑,因为您在问题中使用了两种不同的度量单位。我将尝试解释两者:

PX

这是以像素为单位的高度。这应该和设置字体一样简单:

new Font("Verdana", 16F);

电磁场

这将更难控制,因为这是行高的倍数。比如如果 1em = 14px 那么 16em = (14 * 16)px。除非您知道行高,否则这将很难复制。

该文件还说以下内容

新字体的 em 大小(以磅为单位)。

因此,它以 PX 或像素为您正在使用的构造函数定义。你可以试试这个构造函数,但 EM 实际上是一个根据屏幕动态调整的浏览器/CSS 实现,就像 Vectors。其中 Font 对象是一个位图,用于绘制要绘制的像素数。

http://msdn.microsoft.com/en-us/library/ms141986.aspx

于 2009-01-27T18:11:36.860 回答