2

我的目标是完全适合 toolStripButton 和 toolStripDropDownButton 中的图像。

如果按钮中的图像设置了图像属性,我不能完全适应按钮中的图像。因为边距、边框或按钮的某些东西。(我不确切知道)。

所以我尝试使用 BackgroudImage 属性在按钮中设置图像。在我调整了一些属性(如 AutoSize、Size 等......)后,我可以将图像放入按钮中。

但在这种情况下,我看不到背景图像。当鼠标光标位于按钮上时,它会消失。

我怎么解决这个问题??

图像属性。我无法消除图像之间的差距。 替代文字

背景图像属性。当鼠标光标在图像上时,我看不到图像。 替代文字

4

2 回答 2

3

好吧,你发现了为什么它会在 Image 属性周围留下一个空间。您可以通过分配 ToolStrip.Renderer 属性来自定义按钮的呈现。这可能看起来像这样:

public partial class Form1 : Form {
    public Form1() {
        InitializeComponent();
        toolStrip1.Renderer = new MyRenderer();
    }
    private class MyRenderer : ToolStripProfessionalRenderer {
        protected override void OnRenderButtonBackground(ToolStripItemRenderEventArgs e) {
            if (e.Item.BackgroundImage == null) base.OnRenderButtonBackground(e);
            else {
                Rectangle bounds = new Rectangle(Point.Empty, e.Item.Size);
                e.Graphics.DrawImage(e.Item.BackgroundImage, bounds);
                if (e.Item.Pressed) {
                    // Something...
                }
                else if (e.Item.Selected) {
                    // Something...
                }
                using (Pen pen = new Pen(Color.Black)) {
                    e.Graphics.DrawRectangle(pen, bounds.X, bounds.Y, bounds.Width - 1, bounds.Height - 1);
                }
            }
        }
    }

}

您必须填写 //Something... 行并进行某种绘图,使用户可以清楚地看到该按钮被按下或选中。也许用粗笔画一个矩形,这取决于你。

于 2010-03-22T21:53:02.317 回答
2

当您在 ToolStripButton 的背景中显示图像时,将鼠标移到它上面会导致它消失,这是设计的。ToolStripButton 的 MouseOver 效果绘制在任何背景图像之上,否则将永远看不到效果。

在设置 ToolStripButton 的 Image 属性时,请确保将 ImageScaling 设置为“无”,以保证 AutoSizing 功能会按比例放大 ToolStripButton 以适合图像大小。

“图像之间的间隙”被设计到 ToolStrip 对象中,以便用户知道一个按钮在哪里结束,另一个按钮从哪里开始。

于 2010-03-22T21:22:10.167 回答