精华内容
下载资源
问答
  • 第一步:新建结构体,用于存储窗体属性 第二步:新建集合用于存储对应控件结构的属性 第三步:将控件的属性添加到集合中 第四步:计算出放大和缩小的比例 第五步:输出实际的控件大小 参考:...

    第一步:新建结构体,用于存储窗体属性
    第二步:新建集合用于存储对应控件结构的属性
    第三步:将控件的属性添加到集合中
    第四步:计算出放大和缩小的比例
    第五步:输出实际的控件大小
    参考:https://blog.csdn.net/hy6688_/article/details/19431097

    using System;
    using System.Collections.Generic;
    using System.Diagnostics;
    using System.Drawing;
    using System.Linq;
    using System.Text;
    using System.Threading.Tasks;
    using System.Windows.Forms;
    
    namespace _2DMotionPlatform.FormAutoSizi
    {
        public class FormAutoSize
        {
            // 定义一个控件编号,初始化变量为0,表示窗体本身;后续的为各个控件的编号。
            int CtrNo = 0;
            // 声明一个泛型集合,类型为保存控件属性的结构体
            public List<ControlProperty> OrigenalControl = new List<ControlProperty>();
    
            // 声明一个结构体,用于保存控件的基本属性
            public struct ControlProperty
            {
                public int Left;
                public int Top;
                public int Width;
                public int Height;
                public float FontSize;
            }
            //收集控件的属性到集合中
            public void AddControlToList(Control control)
            {
                ControlProperty Ctp = new ControlProperty();    //新建一个控件属性结构体的实例
                foreach (Control c in control.Controls) {                   //遍历当前引入的控件集
                    Ctp.Left = c.Left;
                    Ctp.Top = c.Top;
                    Ctp.Width = c.Width;
                    Ctp.Height = c.Height;
                    Ctp.FontSize = c.Font.Size;
                    OrigenalControl.Add(Ctp);
                    if (c.Controls.Count > 0) {
                        AddControlToList(c);                   //递归函数调用,防止遗漏嵌套的控件(如:Group、Panel等)
                    }
                }
            }
            // 窗体自适应分辨率
            public void ControlAutoSize(Control MainForm) {
                
                if (CtrNo == 0) {
                    ControlProperty Ctp = new ControlProperty();
                    Ctp.Left = MainForm.Left;
                    Ctp.Top = MainForm.Top;
                    Ctp.Height = MainForm.Height;
                    Ctp.Width = MainForm.Width;
                    Ctp.FontSize = MainForm.Font.Size;
                    //先把主窗体的属性加入到集合
                    OrigenalControl.Add(Ctp);
                    //添加辅窗体控件属性到集合
                    AddControlToList(MainForm);
                }
                //求取分辨率的缩放比例
                float WidthScale = (float)MainForm.Width / (float)OrigenalControl[0].Width;
                float HightScale = (float)MainForm.Height / (float)OrigenalControl[0].Height;
                CtrNo = 1; ;//第0个为窗体本身,窗体内的控件,从序号1开始
                AutoScaleControl(MainForm, WidthScale, HightScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
            }
    
            private void AutoScaleControl(Control mForm, float wScale, float hScale)
            {
                int ctrLeft0, ctrTop0, ctrWidth0, ctrHeight0;
                float ctrFontSize0;
                //第1个是窗体自身的 Left,Top,Width,Height,所以窗体控件从ctrlNo=1开始
                foreach (Control c in mForm.Controls)
                {
                    //获得控件原有的位置和大小信息
                    ctrLeft0 = OrigenalControl[CtrNo].Left;
                    ctrTop0 = OrigenalControl[CtrNo].Top;
                    ctrWidth0 = OrigenalControl[CtrNo].Width;
                    ctrHeight0 = OrigenalControl[CtrNo].Height;
                    ctrFontSize0 = OrigenalControl[CtrNo].FontSize;
                    //设置控件新的位置和大小信息。
                    c.Left = (int)((ctrLeft0) * wScale);//新旧控件之间的线性比例。控件位置只相对于窗体
                    c.Top = (int)((ctrTop0) * hScale);//
                    c.Width = (int)(ctrWidth0 * wScale);//只与最初的大小相关,所以不能与现在的宽度相乘 
                    c.Height = (int)(ctrHeight0 * hScale);//
                    c.Font = new Font(c.Font.Name, (float)(ctrFontSize0 * wScale));//设置控件中字体的大小以适应控件的大小
                    CtrNo++;//累加序号
                    //**放在这里,是先缩放控件本身,后缩放控件的子控件,重点是前后要一致(与保存时)
                    if (c.Controls.Count > 0)
                        AutoScaleControl(c, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
                }
                Debug.Write("如果对象是通过get()方法获取的,而不是new出来的,就可以通过在循环中改变对象的属性的方式来改变集合中该对象的属性值。");
            }
        }
    }
    
    
    实现窗体的自适应分辨率,只需要在窗体的Layout事件中添加如下代码:
            FormAutoSize formAutoSize = new FormAutoSize();
            private void Form1_Layout(object sender, LayoutEventArgs e)
            {
                formAutoSize.ControlAutoSize(this);
            }
    

    注意:无论是通过foreach还是通过for循环遍历的时候,如果对象是通过get()方法获取的,而不是new出来的,就可以通过在循环中改变对象的属性的方式来改变集合中该对象的属性值。因为如果不是new出来的对象,该变量中存的只是从集合中传过来的一个存储真正对象的地址,并不会有这个变量自己的对象,当然也不会占用新的存储空间,当在循环中对该变量所进行的操作,都是对该变量所指向的对象进行的操作,因而会改变集合中对应对象的属性值。
    参考代码下载地址:

    展开全文
  • 自己写的winform窗体自适应大小代码,代码比较独立,很适合贴来贴去不会对原有程序造成影响,可以直接继承此类或者把代码复制到自己的代码里面直接使用 借鉴了网上的一些资料,最后采用重写WndProc方法,这样可以...

    自己写的winform窗体自适应大小代码,代码比较独立,很适合贴来贴去不会对原有程序造成影响,可以直接继承此类或者把代码复制到自己的代码里面直接使用

    借鉴了网上的一些资料,最后采用重写WndProc方法,这样可以兼顾窗体拖拽调整窗体大小和最大化、最小化方法,而且代码比较简练,代码侵入性较小

    using System;
    using System.Collections.Generic;
    using System.Text;
    using System.Windows.Forms;
    using System.Drawing;
    
    namespace LzRabbit
    {
        public class AutoResizeForm : Form
        {
            const int WM_SYSCOMMAND = 0X112;//274
            const int SC_MAXIMIZE = 0XF030;//61488
            const int SC_MINIMIZE = 0XF020;//61472
            const int SC_RESTORE = 0XF120; //61728
            const int SC_CLOSE = 0XF060;//61536
            const int SC_RESIZE_Horizontal = 0XF002;//61442
            const int SC_RESIZE_Vertical = 0XF006;//61446
            const int SC_RESIZE_Both = 0XF008;//61448
    
            protected override void WndProc(ref Message m)
            {
                if (m.Msg == WM_SYSCOMMAND)
                {                switch (m.WParam.ToInt32())
                    {
                        case SC_MAXIMIZE:
                        case SC_RESTORE:
                        case SC_RESIZE_Horizontal:
                        case SC_RESIZE_Vertical:
                        case SC_RESIZE_Both:
                            if (WindowState == FormWindowState.Minimized)
                            {
                                base.WndProc(ref m);
                            }
                            else
                            {
                                Size beforeResizeSize = this.Size;
                                base.WndProc(ref m);
                                //窗口resize之后的大小
                                Size afterResizeSize = this.Size;
                                //获得变化比例
                                float percentWidth = (float)afterResizeSize.Width / beforeResizeSize.Width;
                                float percentHeight = (float)afterResizeSize.Height / beforeResizeSize.Height;
                                foreach (Control control in this.Controls)
                                {
                                    //按比例改变控件大小
                                    control.Width = (int)(control.Width * percentWidth);
                                    control.Height = (int)(control.Height * percentHeight);
                                    //为了不使控件之间覆盖 位置也要按比例变化
                                    control.Left = (int)(control.Left * percentWidth);
                                    control.Top = (int)(control.Top * percentHeight);
                                    //改变控件字体大小
                                    control.Font = new Font(control.Font.Name, control.Font.Size * Math.Min(percentHeight, percentHeight), control.Font.Style, control.Font.Unit);
                                }
                            }
                            break;
                        default:
                            base.WndProc(ref m);
                            break;
                    }
                }
                else
                {
                    base.WndProc(ref m);
                }
            }
        }
    }

     

    展开全文
  • WinForm窗体及其控件自适应,winform控件随窗口自适应,C#源码
  •  2012-11-30 曾经写过 《C# WinForm窗体及其控件自适应各种屏幕分辨率》 ,其中也讲解了控件自适应的原理。近期有网友说,装在panel里面的控件,没有效果?  这是控件嵌套的问题,加入即可实现。使用皮肤时,要注意...

    一。说明
      2012-11-30 曾经写过 《C# WinForm窗体及其控件自适应各种屏幕分辨率》 ,其中也讲解了控件自适应的原理。近期有网友说,装在panel里面的控件,没有效果?
      这是控件嵌套的问题,加入即可实现。使用皮肤时,要注意在窗体Load事件中,有些控件(比如DataGridView)的子控件还没有完成,在这里记录控件的个数比较少,而在窗体SizeChanged事件中获取的比较多(是正常的)。
      解决的方法是,记录控件的初始位置和大小以及处理控件的缩放,都放到窗体SizeChanged事件中,只需第一次记录控件的初始位置和大小,之后再调用类的自适应方法即可。

    二。使用方法
      1.把自适应的类整体复制到你的工程命名空间里,(这样做,每个窗体均可使用)
       然后在需要自适应的窗体中做2步即可:
      2.声明自适应类实例。
      3.为窗体添加SizeChanged事件,并在其方法Form1_SizeChanged中,首次记录窗体和其控件初始位置和大小,之后调用类的自适应方法,完成自适应。

    三。完整代码如下:

    (一)。自适应窗体的代码:
    using System;
    using System.Windows.Forms;
    namespace WindowsFormsApplication1
    {
    public partial class Form1 : Form
    {
    //1.声明自适应类实例
    AutoSizeFormClass asc = new AutoSizeFormClass();
    public Form1()
    {
    InitializeComponent();
    //如果加入"皮肤",则不能在Form1_Load中记录控件的大小和位置,因为有些控件如dataGridView的子控件还未完成
    //而要在在Form1_SizeChanged中,第一次改变时,记录控件的大小和位置
    this.skinEngine1.SkinFile = “EmeraldColor1.ssk”;
    }
    //2. 为窗体添加Load事件,并在其方法Form1_Load中,调用类的初始化方法,记录窗体和其控件的初始位置和大小
    private void Form1_Load(object sender, EventArgs e)
    {
    // asc.controllInitializeSize(this);
    }
    //3.为窗体添加SizeChanged事件,并在其方法Form1_SizeChanged中,调用类的自适应方法,完成自适应
    private void Form1_SizeChanged(object sender, EventArgs e)
    {
    asc.controlAutoSize(this);
    // this.WindowState = (System.Windows.Forms.FormWindowState)(2);//记录完控件的初始位置和大小后,再最大化
    }

    }
    

    }

    (二)。自适应类的代码
    using System.Collections.Generic;
    using System.Windows.Forms;
    namespace WindowsFormsApplication1
    {
    class AutoSizeFormClass
    {
    //(1).声明结构,只记录窗体和其控件的初始位置和大小。
    public struct controlRect
    {
    public int Left;
    public int Top;
    public int Width;
    public int Height;
    }
    //(2).声明 1个对象
    //注意这里不能使用控件列表记录 List nCtrl;,因为控件的关联性,记录的始终是当前的大小。
    // public List oldCtrl= new List();//这里将西文的大于小于号都过滤掉了,只能改为中文的,使用中要改回西文
    public List《controlRect》 oldCtrl = new List《controlRect》();
    int ctrlNo = 0;//1;
    //(3). 创建两个函数
    //(3.1)记录窗体和其控件的初始位置和大小,
    public void controllInitializeSize(Control mForm)
    {
    controlRect cR;
    cR.Left = mForm.Left; cR.Top = mForm.Top; cR.Width = mForm.Width; cR.Height = mForm.Height;
    oldCtrl.Add(cR);//第一个为"窗体本身",只加入一次即可
    AddControl(mForm);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
    //this.WindowState = (System.Windows.Forms.FormWindowState)(2);//记录完控件的初始位置和大小后,再最大化
    //0 - Normalize , 1 - Minimize,2- Maximize
    }
    private void AddControl(Control ctl)
    {
    foreach (Control c in ctl.Controls)
    { //**放在这里,是先记录控件的子控件,后记录控件本身
    //if (c.Controls.Count > 0)
    // AddControl©;//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
    controlRect objCtrl;
    objCtrl.Left = c.Left; objCtrl.Top = c.Top; objCtrl.Width = c.Width; objCtrl.Height = c.Height;
    oldCtrl.Add(objCtrl);
    //**放在这里,是先记录控件本身,后记录控件的子控件
    if (c.Controls.Count > 0)
    AddControl©;//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
    }
    }
    //(3.2)控件自适应大小,
    public void controlAutoSize(Control mForm)
    {
    if (ctrlNo == 0)
    { //*如果在窗体的Form1_Load中,记录控件原始的大小和位置,正常没有问题,但要加入皮肤就会出现问题,因为有些控件如dataGridView的的子控件还没有完成,个数少
    //*要在窗体的Form1_SizeChanged中,第一次改变大小时,记录控件原始的大小和位置,这里所有控件的子控件都已经形成
    controlRect cR;
    // cR.Left = mForm.Left; cR.Top = mForm.Top; cR.Width = mForm.Width; cR.Height = mForm.Height;
    cR.Left = 0; cR.Top = 0; cR.Width = mForm.PreferredSize.Width; cR.Height = mForm.PreferredSize.Height;

                oldCtrl.Add(cR);//第一个为"窗体本身",只加入一次即可
                AddControl(mForm);//窗体内其余控件可能嵌套其它控件(比如panel),故单独抽出以便递归调用
            }
            float wScale = (float)mForm.Width / (float)oldCtrl[0].Width;//新旧窗体之间的比例,与最早的旧窗体
            float hScale = (float)mForm.Height / (float)oldCtrl[0].Height;//.Height;
            ctrlNo = 1;//进入=1,第0个为窗体本身,窗体内的控件,从序号1开始
            AutoScaleControl(mForm, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
        }
        private void AutoScaleControl(Control ctl, float wScale, float hScale)
        {
            int ctrLeft0, ctrTop0, ctrWidth0, ctrHeight0;
            //int ctrlNo = 1;//第1个是窗体自身的 Left,Top,Width,Height,所以窗体控件从ctrlNo=1开始
            foreach (Control c in ctl.Controls)
            { //**放在这里,是先缩放控件的子控件,后缩放控件本身
                 //if (c.Controls.Count > 0)
                 //   AutoScaleControl(c, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
                ctrLeft0 = oldCtrl[ctrlNo].Left;
                ctrTop0 = oldCtrl[ctrlNo].Top;
                ctrWidth0 = oldCtrl[ctrlNo].Width;
                ctrHeight0 = oldCtrl[ctrlNo].Height;
                //c.Left = (int)((ctrLeft0 - wLeft0) * wScale) + wLeft1;//新旧控件之间的线性比例
                //c.Top = (int)((ctrTop0 - wTop0) * h) + wTop1;
                c.Left = (int)((ctrLeft0) * wScale);//新旧控件之间的线性比例。控件位置只相对于窗体,所以不能加 + wLeft1
                c.Top = (int)((ctrTop0) * hScale);//
                c.Width = (int)(ctrWidth0 * wScale);//只与最初的大小相关,所以不能与现在的宽度相乘 (int)(c.Width * w);
                c.Height = (int)(ctrHeight0 * hScale);//
                ctrlNo++;//累加序号
                //**放在这里,是先缩放控件本身,后缩放控件的子控件
                if (c.Controls.Count > 0)
                    AutoScaleControl(c, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
    
                if (ctl is DataGridView)
                {
                    DataGridView dgv = ctl as DataGridView;
                    Cursor.Current = Cursors.WaitCursor;
    
                    int widths = 0;
                    for (int i = 0; i < dgv.Columns.Count; i++)
                    {
                        dgv.AutoResizeColumn(i, DataGridViewAutoSizeColumnMode.AllCells);  // 自动调整列宽  
                        widths += dgv.Columns[i].Width;   // 计算调整列后单元列的宽度和                       
                    }
                    if (widths >= ctl.Size.Width)  // 如果调整列的宽度大于设定列宽  
                        dgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.DisplayedCells;  // 调整列的模式 自动  
                    else
                        dgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;  // 如果小于 则填充  
    
                    Cursor.Current = Cursors.Default;
                }
            }
        }
    }
    

    }
    20140627特此更正:
    1。看到几个用户提到以下语句错误,原因是新浪博客将西文的大于号、小于号中的内容过滤掉了,所以只能改为中文的大于号、小于号,在实际使用中要改回西文
    // public List oldCtrl= new List();//这里将西文的大于小于号都过滤掉了,只能改为中文的,使用中要改回西文
    public List《controlRect》 oldCtrl = new List《controlRect》();
    2。在load中正常,到sizechang中,高度和宽度,应使用mForm.PreferredSize.Width,mForm.PreferredSize.Height;

              //  cR.Left = mForm.Left; cR.Top = mForm.Top; cR.Width = mForm.Width; cR.Height = mForm.Height;
                cR.Left = 0; cR.Top = 0; cR.Width = mForm.PreferredSize.Width; cR.Height = mForm.PreferredSize.Height;
    

    转载为:http://blog.sina.com.cn/s/blog_45eaa01a0101c7ko.html###

    展开全文
  • C# WinForm窗体及其控件自适应各种屏幕分辨率 2016年07月13日 17:12:31 source0573 阅读数 9327 1.声明AutoSizeFormClass类 using System; using System.Collections.Generic; using System....

    C# WinForm窗体及其控件自适应各种屏幕分辨率

    2016年07月13日 17:12:31 source0573 阅读数 9327

    1.声明AutoSizeFormClass类

     

     
    1. using System;

    2. using System.Collections.Generic;

    3. using System.Linq;

    4. using System.Text;

    5. using System.Windows.Forms;

    6.  
    7. namespace WindowsApplication1

    8. {

    9. public class AutoSizeFormClass

    10. {

    11. //(1).声明结构,只记录窗体和其控件的初始位置和大小。

    12. public struct controlRect

    13. {

    14. public int Left;

    15. public int Top;

    16. public int Width;

    17. public int Height;

    18. }

    19. //(2).声明 1个对象

    20. //注意这里不能使用控件列表记录 List nCtrl;,因为控件的关联性,记录的始终是当前的大小。

    21. // public List oldCtrl= new List();//这里将西文的大于小于号都过滤掉了,只能改为中文的,使用中要改回西文

    22. public List<controlRect> oldCtrl = new List<controlRect>();

    23. int ctrlNo = 0;//1;

    24. //(3). 创建两个函数

    25. //(3.1)记录窗体和其控件的初始位置和大小,

    26. public void controllInitializeSize(Control mForm)

    27. {

    28. controlRect cR;

    29. cR.Left = mForm.Left; cR.Top = mForm.Top; cR.Width = mForm.Width; cR.Height = mForm.Height;

    30. oldCtrl.Add(cR);//第一个为"窗体本身",只加入一次即可

    31. AddControl(mForm);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用

    32. //this.WindowState = (System.Windows.Forms.FormWindowState)(2);//记录完控件的初始位置和大小后,再最大化

    33. //0 - Normalize , 1 - Minimize,2- Maximize

    34. }

    35. private void AddControl(Control ctl)

    36. {

    37. foreach (Control c in ctl.Controls)

    38. { //**放在这里,是先记录控件的子控件,后记录控件本身

    39. //if (c.Controls.Count > 0)

    40. // AddControl(c);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用

    41. controlRect objCtrl;

    42. objCtrl.Left = c.Left; objCtrl.Top = c.Top; objCtrl.Width = c.Width; objCtrl.Height = c.Height;

    43. oldCtrl.Add(objCtrl);

    44. //**放在这里,是先记录控件本身,后记录控件的子控件

    45. if (c.Controls.Count > 0)

    46. AddControl(c);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用

    47. }

    48. }

    49. //(3.2)控件自适应大小,

    50. public void controlAutoSize(Control mForm)

    51. {

    52. if (ctrlNo == 0)

    53. { //*如果在窗体的Form1_Load中,记录控件原始的大小和位置,正常没有问题,但要加入皮肤就会出现问题,因为有些控件如dataGridView的的子控件还没有完成,个数少

    54. //*要在窗体的Form1_SizeChanged中,第一次改变大小时,记录控件原始的大小和位置,这里所有控件的子控件都已经形成

    55. controlRect cR;

    56. // cR.Left = mForm.Left; cR.Top = mForm.Top; cR.Width = mForm.Width; cR.Height = mForm.Height;

    57. cR.Left = 0; cR.Top = 0; cR.Width = mForm.PreferredSize.Width; cR.Height = mForm.PreferredSize.Height;

    58.  
    59. oldCtrl.Add(cR);//第一个为"窗体本身",只加入一次即可

    60. AddControl(mForm);//窗体内其余控件可能嵌套其它控件(比如panel),故单独抽出以便递归调用

    61. }

    62. float wScale = (float)mForm.Width / (float)oldCtrl[0].Width;//新旧窗体之间的比例,与最早的旧窗体

    63. float hScale = (float)mForm.Height / (float)oldCtrl[0].Height;//.Height;

    64. ctrlNo = 1;//进入=1,第0个为窗体本身,窗体内的控件,从序号1开始

    65. AutoScaleControl(mForm, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用

    66. }

    67. private void AutoScaleControl(Control ctl, float wScale, float hScale)

    68. {

    69. int ctrLeft0, ctrTop0, ctrWidth0, ctrHeight0;

    70. //int ctrlNo = 1;//第1个是窗体自身的 Left,Top,Width,Height,所以窗体控件从ctrlNo=1开始

    71. foreach (Control c in ctl.Controls)

    72. { //**放在这里,是先缩放控件的子控件,后缩放控件本身

    73. //if (c.Controls.Count > 0)

    74. // AutoScaleControl(c, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用

    75. ctrLeft0 = oldCtrl[ctrlNo].Left;

    76. ctrTop0 = oldCtrl[ctrlNo].Top;

    77. ctrWidth0 = oldCtrl[ctrlNo].Width;

    78. ctrHeight0 = oldCtrl[ctrlNo].Height;

    79. //c.Left = (int)((ctrLeft0 - wLeft0) * wScale) + wLeft1;//新旧控件之间的线性比例

    80. //c.Top = (int)((ctrTop0 - wTop0) * h) + wTop1;

    81. c.Left = (int)((ctrLeft0) * wScale);//新旧控件之间的线性比例。控件位置只相对于窗体,所以不能加 + wLeft1

    82. c.Top = (int)((ctrTop0) * hScale);//

    83. c.Width = (int)(ctrWidth0 * wScale);//只与最初的大小相关,所以不能与现在的宽度相乘 (int)(c.Width * w);

    84. c.Height = (int)(ctrHeight0 * hScale);//

    85. ctrlNo++;//累加序号

    86. //**放在这里,是先缩放控件本身,后缩放控件的子控件

    87. if (c.Controls.Count > 0)

    88. AutoScaleControl(c, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用

    89.  
    90. if (ctl is DataGridView)

    91. {

    92. DataGridView dgv = ctl as DataGridView;

    93. Cursor.Current = Cursors.WaitCursor;

    94.  
    95. int widths = 0;

    96. for (int i = 0; i < dgv.Columns.Count; i++)

    97. {

    98. dgv.AutoResizeColumn(i, DataGridViewAutoSizeColumnMode.AllCells); // 自动调整列宽

    99. widths += dgv.Columns[i].Width; // 计算调整列后单元列的宽度和

    100. }

    101. if (widths >= ctl.Size.Width) // 如果调整列的宽度大于设定列宽

    102. dgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.DisplayedCells; // 调整列的模式 自动

    103. else

    104. dgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill; // 如果小于 则填充

    105.  
    106. Cursor.Current = Cursors.Default;

    107. }

    108. }

    109.  
    110.  
    111. }

    112. }

    113. }


    2.为窗体添加Load事件,并在其方法Form1_Load中,调用类的初始化方法,记录窗体和其控件初始位置和大小

    3.为窗体添加SizeChanged事件,并在其方法Form1_SizeChanged中,调用类的自适应方法,完成自适应

     

     
    1. using System;

    2. using System.Collections.Generic;

    3. using System.ComponentModel;

    4. using System.Data;

    5. using System.Drawing;

    6. using System.Text;

    7. using System.Windows.Forms;

    8.  
    9. namespace WindowsApplication1

    10. {

    11. public partial class Form1 : Form

    12. {

    13. //1.声明自适应类实例

    14. AutoSizeFormClass asc = new AutoSizeFormClass();

    15.  
    16. public Form1()

    17. {

    18. InitializeComponent();

    19. }

    20.  
    21. //2. 为窗体添加Load事件,并在其方法Form1_Load中,调用类的初始化方法,记录窗体和其控件的初始位置和大小

    22. private void Form1_Load(object sender, EventArgs e)

    23. {

    24. asc.controllInitializeSize(this);

    25. }

    26.  
    27. //3.为窗体添加SizeChanged事件,并在其方法Form1_SizeChanged中,调用类的自适应方法,完成自适应

    28. private void Form1_SizeChanged(object sender, EventArgs e)

    29. {

    30. asc.controlAutoSize(this);

    31. }

    32. }

    33. }

    展开全文
  • 1.项目情况:项目使用winform搭建,禁用用户放大缩小,一直全屏展示 2.问题: a.用tableLayoutPanel加panel能不能做到自适应布局呢?(保证布局不跑偏) b.如果a成立那么里面的控件如何做到按照屏幕分辨率等比缩放呢,...
  • C#Winform 实现控件自适应父容器大小 在日常开发中经常遇到控件不能随着父容器大小的改变而且自动改变控件的所在位置和大小。以下是实现的代码 `/// <summary> /// 根据父容器实现控件自适应大小位置 /// &...
  • 窗体自适应,统计原始窗体的位置和大小;缩放后Resize通过计算主窗体的大小,计算出长宽伸缩比例,然后再计算出来内部控件的起始点和长宽,过程通过递归完成,简单易行!
  • C#winform 窗体缩放自适应

    千次阅读 2018-09-10 11:14:00
    1. 首先在窗体上放上一个Panel容器,并将容器的Dock属性设为Fill,即所有的控件都放在了这个容器里。 using System; using System.Collections.Generic; using System.Drawing; using System.Text; using ...
  • Winform 窗体控件自适应大小

    千次阅读 2018-03-01 14:27:05
    在需要自适应的Form中实例化全局变量 AutoSizeFormClass.cs源码在下方 AutoSizeFormClass asc = new AutoSizeFormClass();2.Form_Load事件中 asc.controllInitializeSize(this);3.Page_SizeChanged事件中 asc....
  • 本来不爱鸡汤,今天说两句:winform开发有一个缺陷就是不能实现界面的自适应,切换不同的分辨率,或者窗体大小改变就会出现窗体显示不全的问题。这就需要自己写一个方法来实现不同情况下的自适应,WPF比Winform的一...
  • Winform窗体各个控件自适应电脑屏幕

    千次阅读 2017-03-09 12:42:49
    private Size beforeResizeSize = Size... //为了不使控件之间覆盖 位置也要按比例变化  control.Left = (int)(control.Left * percentWidth);  control.Top = (int)(control.Top * percentHeight);  } }
  • WinForm窗体及其控件的自适应, 很简单的一个程序。实现窗体控件自动适应屏幕位置

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 543
精华内容 217
关键字:

winform窗体控件自适应