5

如何完全删除标签控件中的填充?

我试图将 Margin 和 Padding 属性设置为零,但标签内的边距仍然很少。

我希望 Windows 窗体中的左右填充为零或非常小(小于“空格”字符宽度的一半)。

我需要这个标签放置非常靠近其他标签,但是当我放置标签非常靠近时 - 放置在顶部的标签背景覆盖其他标签文本。我在一个标签上使用右对齐,在另一个标签上使用左对齐,它看起来像这样:

填充

无论 AutoSize 属性如何,我都有这个问题。控件右侧总是有太多的填充。

在 WPF 中,它可以按我的意愿工作,但我必须使用 Windows 窗体。

我不能使用 TextBox 控件(它可以在我想要的地方工作),因为它不支持透明背景。

4

3 回答 3

3

尝试将 UseCompatibleTextRendering 属性设置为true

于 2016-07-22T02:05:06.133 回答
2

如果您自己绘制文本,您可以完全删除填充。这是一个简单的自定义标签控件(RightAlignment 属性更改文本对齐方式)

public partial class NoPaddingLabel : Label
{
    private TextFormatFlags flags = TextFormatFlags.SingleLine | TextFormatFlags.VerticalCenter | TextFormatFlags.Left | TextFormatFlags.NoPadding;

    public bool RightAlignment
    {
        get
        {
            return (flags & TextFormatFlags.Right) == TextFormatFlags.Right;
        }
        set
        {
            if (value)
            {
                flags = flags |= TextFormatFlags.Right;
            }
            else
            {
                flags = flags &= ~TextFormatFlags.Right;
            }
            Invalidate();
        }
    }


    public NoPaddingLabel()
    {
        InitializeComponent();
    }

    protected override void OnPaint(PaintEventArgs e)
    {
        TextRenderer.DrawText(e.Graphics, this.Text, this.Font, ClientRectangle, this.ForeColor, Color.Transparent, flags);
    }

}
于 2015-01-13T14:51:59.273 回答
0

我使用 Canvas 布局来解决这个问题:

<Canvas>
   <Label Canvas.Left="35" Canvas.Top="0" Content="Latitude:" HorizontalAlignment="Right" Foreground="red"/>
   <Label Canvas.Left="90" Canvas.Top="0" Content="nn.nnnnnn" Foreground="red" />
   <Label Canvas.Left="25" Canvas.Top="12"  Content="Longitude:" HorizontalAlignment="Right" Foreground="red"/>
   <Label Canvas.Left="90" Canvas.Top="12"  Content="nn.nnnnnn" Foreground="red" />
   <Label Canvas.Left="40" Canvas.Top="26"  Content="Date" HorizontalAlignment="Center" Foreground="Blue"/>
   <Label Canvas.Left="100" Canvas.Top="26"  Content="Time" HorizontalAlignment="Center" Foreground="Blue"/>
</Canvas>
于 2021-10-19T07:50:07.927 回答