C#Winform窗体工具类(五)鼠标访问 改变控件 背景色

8 篇文章 0 订阅

在开发中,有一些常常用到的方法,每次查找以前写的比较麻烦 ,自己写有在做重复工作 ,所以总一个小的工具类,随时添加内容

5.winform访问控件改变背景色  静态类 FormTools( public static class FormTools)

5.1控件A触发改变本身背景色 (此处A: contrl)
            /// <summary>
            /// 鼠标移入背景动画 (注册控件A 只触发事件只改变改变 A 的背景)
            /// </summary>
            /// <param name="contrl">要触发事件的控件</param>
            /// <param name="hoverColor">鼠标访问时背景色</param>
            public static void HoverBackColor(this Control contrl, Color hoverColor)
            {
                var leaveColor = contrl.BackColor;
                contrl.MouseEnter+= (sender, e) =>
                {
                    contrl.BackColor =hoverColor;
                };
                 contrl.MouseLeave+= (sender, e) =>
                {
                    contrl.BackColor = leaveColor;
                };
            }
5.2控件A触发改变控件B 背景色 (此处A: contrl,  B: con)
            /// <summary>
            /// 鼠标移入背景动画 (注册控件A 触发事件改变 B 的背景色)
            /// </summary>
            /// <param name="contrl">要触发事件的控件</param>
            /// <param name="con">要改变的背景颜色</param>
            /// <param name="hoverColor">鼠标访问时背景色</param>
            public static void HoverBackColor(this Control contrl,Control  con, Color hoverColor)
            {
                var leaveColor = con.BackColor;
                contrl.MouseEnter += (sender, e) =>
                {
                    con.BackColor = hoverColor;
                };
                contrl.MouseLeave += (sender, e) =>
                {
                    con.BackColor = leaveColor;
                };
            }
5.3 一组控件 触发改变 本身 背景色 (一组控件: control)
        /// <summary>
        /// 鼠标移入背景动画 (注册一组控件控件B,C,D...触发改变 本身 的背景色)
        /// </summary>
        /// <param name="contrl">要触发事件的控件</param>
        /// <param name="hoverColor">鼠标访问时背景色</param>
        public static void HoverBackColor( Control[] contrl,Color hoverColor)
        {
            foreach (var con in contrl)
            {
                var leaveColor = con.BackColor;
                con.MouseEnter += (sender, e) =>
                {
                    con.BackColor = hoverColor;
                };
                con.MouseLeave += (sender, e) =>
                {
                    con.BackColor = leaveColor;
                };
            }

        }
5.4 一组控件触发改变 控件A的背景色 (一组控件: control ,控件 A :con)
            /// <summary>
            /// 鼠标移入背景动画 (注册一组控件B,C,D...触发改变 A 的背景色)
            /// </summary>
            /// <param name="contrl">要触发事件的控件</param>
            /// <param name="con">要改变的控件颜色</param>
            /// <param name="hoverColor">鼠标访问时背景色</param>
            public static void HoverBackColor(this Control con,Control [] contrl, Color hoverColor)
            {
                foreach (var c in contrl)
                {
                    var leaveColor = con.BackColor;
                    c.MouseEnter += (sender, e) =>
                    {
                        con.BackColor = hoverColor;
                    };
                    c.MouseLeave += (sender, e) =>
                    {
                        con.BackColor = leaveColor;
                    };
                }
           
        }

调用

5.1 改变窗体背景色为 红色
this.HoverBackColor(Color.Red);
5.2 鼠标访问Panel1时 改变窗体背景色 为红色 
this.Panel1.HoverBackColor(this, Color.Red);
5.3 鼠标访问控件 times,label1 时改变它自己的背景色 为红色
FormTools.HoverBackColor(new Control[] { this.times,  this.label1 }, Color.Red);
5.4 鼠标访问控件 times,label1 时改变 panel1 的背景色 为红色
this.Panel1.HoverBackColor(new Control[] { this.times,  this.label1},Color.Red);            








  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在C# WinForm窗体中,如果你想要在表格控件上填充颜色,但是鼠标经过其他控件时整个表格里的数据都变了,可能是因为你在窗体上直接绘制了表格,而没有使用自定义控件来解决这个问题。\[1\] 你可以尝试使用自适应类来解决这个问题。首先,将自适应类的代码复制到你的工程命名空间中,然后声明自适应类的实例。接下来,在窗体上添加SizeChanged事件,并在事件方法中记录窗体控件的初始位置和大小。最后,调用自适应类的自适应方法,完成自适应。这样,你就可以在表格控件上填充颜色而不会受到其他控件的影响了。\[2\] 你还可以使用Panel、DataGridView等控件来实现自适应。\[2\] 在窗体的代码中,你需要引入System、System.Collections.Generic、System.ComponentModel、System.Drawing和System.Windows.Forms这些命名空间,并在窗体的Load事件中调用自适应类的初始化方法,记录窗体控件的初始位置和大小。然后,在窗体的SizeChanged事件中调用自适应类的自适应方法,完成自适应。\[3\] 这样,你就可以在C# WinForm窗体中使用表格控件,并且实现自适应的效果了。 #### 引用[.reference_title] - *1* [C#自定义控件实现窗体绘制表格](https://blog.csdn.net/qq_22955427/article/details/76252582)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [C# WinForm 窗体及其控件的自适应](https://blog.csdn.net/chbxgbin/article/details/109690260)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值