c# winform 窗体基于分辨率自适应处理

代码参考资料:WindowsFormsApplication1.zip-C#文档类资源-CSDN下载

普通的winform属性需要设置一下,尽量不要继承Cskin第三方用的话设置【this.CanResize = true】:

绝大部分优先使用dpi好使,原始 有些font好使

label、button这些控件 autosize=true

如果winform中嵌入 usercontrol用户控件,那这个窗体需要设置:

load事件加载复制            
#region 计算dpi值
            float dpiX;
            Graphics graphics = this.CreateGraphics();
            dpiX = graphics.DpiX;

            switch (dpiX)
            {
                case 96f:
                    dpiValue = 1.0f;
                    break;
                case 120f:
                    dpiValue = 1.25f;
                    break;
                case 144f:
                    dpiValue = 1.5f;
                    break;
                case 168f:
                    dpiValue = 1.75f;
                    break;
                case 192f:
                    dpiValue = 2.0f;
                    break;
            }
            #endregion

针对有些长宽、坐标调整的 值*dpiValue

/// <summary>
        /// 获取windows缩放比
        /// </summary>
        /// <returns></returns>
        public static float GetWindowsZoomRatio(Graphics graphics)
        {
            float dpiX = graphics.DpiX;

            float zoomRatio = 1.0f;

            switch (dpiX)
            {
                case 96f:
                    zoomRatio = 1.0f;
                    break;
                case 120f:
                    zoomRatio = 1.25f;
                    break;
                case 144f:
                    zoomRatio = 1.5f;
                    break;
                case 168f:
                    zoomRatio = 1.75f;
                    break;
                case 192f:
                    zoomRatio = 2.0f;
                    break;
                case 216f:
                    zoomRatio = 2.25f;
                    break;
                case 240f:
                    zoomRatio = 2.5f;
                    break;
                case 264f:
                    zoomRatio = 2.75f;
                    break;
                case 288f:
                    zoomRatio = 3.0f;
                    break;
                case 312f:
                    zoomRatio = 3.25f;
                    break;
                case 336f:
                    zoomRatio = 3.5f;
                    break;
                case 360f:
                    zoomRatio = 3.75f;
                    break;
                case 384f:
                    zoomRatio = 4.0f;
                    break;
                case 408f:
                    zoomRatio = 4.25f;
                    break;
                case 432f:
                    zoomRatio = 4.5f;
                    break;
                case 456f:
                    zoomRatio = 4.75f;
                    break;
                case 480f:
                    zoomRatio = 5.0f;
                    break;
            }

            return zoomRatio;
        }

回答: 在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 ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值