C#之winform设置控件居中

在C#的窗体编程,winfrom里面,原生控件卧槽般的坑爹,没有居中这种属性,这是很恶心的一件事情。

对比java的窗体,有不少布局是支持设置居中的,android更不用说。而winfrom这家伙没有。虽然java的窗体很丑很丑很丑,可C#在这方面实在是吐血到人了,一方面是非常优秀的图形化设计,一拖一拉,就设计好了,一边是坑爹般的居中属性没看到。

更坑爹的是,百度出来的答案净说废话,无图无真相。资料很少。

最终还得亲自出马,上穷碧落下黄泉,解决了这个问题:

1、通用型:重写OnResize(EventArgs e)方法,通过计算,重新定位控件的位置。(优点:准确,通用,即使窗体改变也能使用;缺点:麻烦,不爽,并且只有在运行的时候才能看到效果)

2、万能型:直接在属性界面计算出居中坐标,设置为控件的Location属性值。并设置锚点Anchor为Top,钉住控件顶部位置。(优点:准确,通用,能够实时预览;缺点:尼玛,一个控件算一次,算完还得写上去,不吐血?好,万一窗体大小改变了,万一有很多个控件呢?算不死你,小样的)

以上两种方法都是通过计算确定位置,一个是代码去确定的,一个是人工计算并填写,所以不止能设置居中,什么居左,居右,居上,居下,都是可以的。前提是,很烦。

3、Label控件:将label的AutoSize属性设置为false,把label控件拉满或设置Dock属性为fill,填满父容器,再设置TextAlgin为MiddleCenter(居中)即可。(优点:动动鼠标就ok,实时预览;缺点:只适用于不设置背景的label控件,label设置背景就和按钮一样了,而且控件多了尼玛互相覆盖,洒得到处都是)

属性说明:
AutoSize(false):取消自动调整大小,这样控件就不会随窗体的改变而改变大小,位置等,并能够自定义控件的区域,位置等。

TextAlgin(MiddleCenter):文本对齐方式为居中。label的尺寸一般总是刚刚包围住所有文字,而且又是透明的,所以,正常情况下该属性没什么效果,只有当控件的区域比文字区域大了很多时,文字才明显不对头了。这时,就需要设置对齐方式。类似于对齐子控件,内容。

重写以设置居中的代码:

 protected override void OnResize(EventArgs e)
        {
            base.OnResize(e);
            int x = (int)(0.5 * (this.Width - label1.Width));
            int y = label1.Location.Y;
            label1.Location = new System.Drawing.Point(x,y);

        }

当然也可以在代码设计器方法中用代码进行计算,但意义不大,结果是导致预览界面引发异常或错误,但程序运行则能够正常显示。

用代码重写OnResize方法,控制控件居中示意图:

这里写图片描述

并且放大依然保持居中:
这里写图片描述

  • 9
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
WinForm TabControl 默认不支持切换动画,但是我们可以通过编写自定义控件来实现这一功能。以下是实现 WinForm TabPage 切换动画的一种方式: 1. 创建一个自定义控件类,继承 TabControl 控件; 2. 添加一个成员变量,用于存储当前激活的 TabPage 索引; 3. 重载 OnSelecting 方法,在该方法中记录当前激活的 TabPage 索引; 4. 重载 OnPaint 方法,在该方法中根据当前激活的 TabPage 索引绘制动画效果。 示例代码如下: ```csharp public class AnimatedTabControl : TabControl { private int _lastSelectedIndex = -1; protected override void OnSelecting(TabControlCancelEventArgs e) { base.OnSelecting(e); // 记录当前激活的 TabPage 索引 _lastSelectedIndex = SelectedIndex; } protected override void OnPaint(PaintEventArgs e) { base.OnPaint(e); if (_lastSelectedIndex == -1 || SelectedIndex == _lastSelectedIndex) return; // 获取当前激活的 TabPage 和上一次激活的 TabPage var currentTabPage = SelectedTab; var lastTabPage = TabPages[_lastSelectedIndex]; // 计算动画效果的参数 var direction = SelectedIndex > _lastSelectedIndex ? 1 : -1; var width = Width; var height = Height; var currentStartX = direction > 0 ? width : -width; var lastEndX = direction > 0 ? -width : width; // 绘制动画 using (var currentBitmap = new Bitmap(width, height, e.Graphics)) using (var lastBitmap = new Bitmap(width, height, e.Graphics)) using (var currentGraphics = Graphics.FromImage(currentBitmap)) using (var lastGraphics = Graphics.FromImage(lastBitmap)) { currentGraphics.SetClip(currentTabPage.Bounds); lastGraphics.SetClip(lastTabPage.Bounds); // 绘制当前激活的 TabPage currentGraphics.TranslateTransform(currentStartX, 0); InvokePaint(currentGraphics, currentTabPage); e.Graphics.DrawImage(currentBitmap, 0, 0); // 绘制上一次激活的 TabPage lastGraphics.TranslateTransform(lastEndX, 0); InvokePaint(lastGraphics, lastTabPage); e.Graphics.DrawImage(lastBitmap, 0, 0); } // 重置激活状态 _lastSelectedIndex = SelectedIndex; } } ``` 使用该自定义控件时,只需将原来的 TabControl 替换为 AnimatedTabControl 即可: ```csharp var animatedTabControl = new AnimatedTabControl(); animatedTabControl.TabPages.Add(new TabPage("Tab 1")); animatedTabControl.TabPages.Add(new TabPage("Tab 2")); animatedTabControl.TabPages.Add(new TabPage("Tab 3")); ``` 这样,当用户切换 TabPage 时,就会出现从右到左或从左到右的动画效果。
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值