- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
System.Windows.Forms.TextRenderer.DrawText
方法呈现带或不带左右填充的格式化文本,具体取决于 flags
参数的值:
TextFormatFlags.NoPadding
- 将文本紧密地放入边界框,TextFormatFlags.GlyphOverhangPadding
- 添加一些左右边距,TextFormatFlags.LeftAndRightPadding
- 添加更大的边距。现在,我的问题是对于给定的设备上下文、字符串、字体等?
我用 .NET Reflector 深入研究了 .NET 4,发现 TextRenderer 计算“悬垂填充”,它是字体高度的 1/6,然后乘以该值以使用这些系数计算左右边距:
TextFormatFlags.GlyphOverhangPadding
左 1.0,右 1.5,TextFormatFlags.LeftAndRightPadding
左 2.0,右 2.5。结果值被四舍五入并传递给 DrawTextExA
或 DrawTextExW
native API 函数。很难重新创建此过程,因为字体的高度不是从 System.Drawing.Font
而是从 System.Windows.Forms.Internal.WindowsFont
获取的,并且这些类返回不同的值相同的字体。还涉及 System.Windows.Forms.Internal
命名空间中的许多其他内部 BCL 类。反编译它们并在我的应用程序中重用它们的代码不是一种选择,因为那将是一个严重的 .NET 实现依赖项。这就是为什么我需要知道 WinForms 中是否有一些公共(public) API,或者至少我可以使用哪些 Windows 函数来获取左右边距的值。
注意:我尝试使用和不使用填充来 TextRenderer.MeasureText
并比较结果,但这只给了我左右边距的总和,我需要他们分开。
注意 2:如果您想知道我为什么需要这个:我想用多种字体/颜色绘制一个字符串。这涉及使用 NoPadding
选项为每个统一格式的子字符串调用一次 DrawText
(这样文本就不会展开),但我还想手动添加正常的 GlyphOverhangPadding
在整个多格式文本的开头和结尾。
最佳答案
计算左右边距所需的值是 TEXTMETRIC.tmHeight,可以使用 Win32 API 获得。 .
但是,我发现 tmHeight 只是字体的行高(以像素为单位),因此这三种方法将为您提供相同的值(您可以在代码中使用任何您喜欢的值):
int apiHeight = GetTextMetrics(graphics, font).tmHeight;
int gdiHeight = TextRenderer.MeasureString(...).Height;
int gdipHeight = (int)Math.Ceiling(font.GetHeight(graphics));
为了获得左边距和右边距,我们使用与 TextRenderer 相同的代码:
private const float ItalicPaddingFactor = 0.5f;
...
float overhangPadding = (gdiHeight / 6.0f);
//NOTE: proper margins for TextFormatFlags.LeftAndRightPadding flag
//int leftMargin = (int)Math.Ceiling(overhangPadding);
//int rightMargin = (int)Math.Ceiling(overhangPadding * (2 + ItalicPaddingFactor));
//NOTE: proper margins for TextFormatFlags.GlyphOverhangPadding flag
int leftMargin = (int)Math.Ceiling(overhangPadding);
int rightMargin = (int)Math.Ceiling(overhangPadding * (1 + ItalicPaddingFactor));
Size sizeOverhangPadding = TextRenderer.MeasureText(e.Graphics, "ABC", font, Size.Empty, TextFormatFlags.GlyphOverhangPadding);
Size sizeNoPadding = TextRenderer.MeasureText(e.Graphics, "ABC", font, Size.Empty, TextFormatFlags.NoPadding);
int overallPadding = (sizeOverhangPadding.Width - sizeNoPadding.Width);
现在你可以很容易地检查
(leftMargin + rightMargin) == overallPadding
请注意:
我需要解决这个问题才能在 ListView-based control 中实现“搜索突出显示”功能使用 GDI 文本呈现:
工作起来很有魅力:)
关于c# - 如何获取 TextRenderer 使用的确切文本边距,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4428335/
通过多次搜索和pytorch文档本身,我可以发现在嵌入层内部有一个查找表,用于存储嵌入向量。我无法理解的是: 在这一层的培训期间究竟发生了什么? 权重是多少,以及这些权重的梯度是如何计算的? 我的直觉
当应用程序有大量数据(400M)要写入非阻塞套接字时,write() 返回EWOULDBLOCK 或EAGAIN 当发送缓冲区变满时。 当套接字被(e)轮询时,我有时会看到发送缓冲区中有 7M 空间(
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我经常阅读一些编程语言对模块的支持(“一流”)(OCaml,Scala,TypeScript [?]),并且最近偶然发现了这样的答案,即在Scala的显着特征中引用模块作为一流公民。 我以为我很清楚模
我已经提交了一个自定义的开放图表故事,但它被拒绝并显示以下消息: 打开图表捐赠(行动类型)提交内容、操作、对象和使用说明必须以英文提交。您可以在应用程序面板的“本地化”选项卡中翻译操作和对象。 如果我
给定一个任意的 boolean 值列表,确定其中一个恰好为真的最优雅的方法是什么? 最明显的 hack 是类型转换:将 false 转换为 0,将 true 转换为 1,然后对它们求和,并返回 sum
这个问题在这里已经有了答案: When to use extern "C" in simple words? [duplicate] (7 个答案) 关闭 9 年前。 如果您想将此问题标记为重复问题
我是一名优秀的程序员,十分优秀!