1. using System.Runtime.InteropServices;
  2.  
  3. public class Win32
  4. {
  5. public const Int32 AW_HOR_POSITIVE = 0x00000001; // 从左到右打开窗口
  6. public const Int32 AW_HOR_NEGATIVE = 0x00000002; // 从右到左打开窗口
  7. public const Int32 AW_VER_POSITIVE = 0x00000004; // 从上到下打开窗口
  8. public const Int32 AW_VER_NEGATIVE = 0x00000008; // 从下到上打开窗口
  9. public const Int32 AW_CENTER = 0x00000010;
  10. public const Int32 AW_HIDE = 0x00010000; // 在窗体卸载时若想使用本函数就得加上此常量
  11. public const Int32 AW_ACTIVATE = 0x00020000; //在窗体通过本函数打开后,默认情况下会失去焦点,除非加上本常量
  12. public const Int32 AW_SLIDE = 0x00040000;
  13. public const Int32 AW_BLEND = 0x00080000; // 淡入淡出效果
  14. [DllImport("user32.dll", CharSet = CharSet.Auto)]
  15. public static extern bool AnimateWindow(
  16. IntPtr hwnd, // handle to window
  17. int dwTime, // duration of animation
  18. int dwFlags // animation type
  19. );
  20. }
  21.  
  22. /*淡入窗体*/
  23. private void Form_Load(object sender, EventArgs e)
  24. {
  25. Win32.AnimateWindow(this.Handle, , Win32.AW_BLEND);
  26. }
  27. /*淡出窗体*/
  28. private void Form_FormClosing(object sender, FormClosingEventArgs e)
  29. {
  30. Win32.AnimateWindow(this.Handle, , Win32.AW_SLIDE | Win32.AW_HIDE | Win32.AW_BLEND);
  31. }
    //https://blog.csdn.net/a237428367/article/details/5933565
  1. class AutoSizeFormClass
  2. {
  3. //(1).声明结构,只记录窗体和其控件的初始位置和大小。
  4. public struct controlRect
  5. {
  6. public int Left;
  7. public int Top;
  8. public int Width;
  9. public int Height;
  10. }
  11. //(2).声明 1个对象
  12. //注意这里不能使用控件列表记录 List nCtrl;,因为控件的关联性,记录的始终是当前的大小。
  13. // public List oldCtrl= new List();//这里将西文的大于小于号都过滤掉了,只能改为中文的,使用中要改回西文
  14. public List<controlRect> oldCtrl = new List<controlRect>();
  15. int ctrlNo = ;//1;
  16. //(3). 创建两个函数
  17. //(3.1)记录窗体和其控件的初始位置和大小,
  18. public void controllInitializeSize(Control mForm)
  19. {
  20. controlRect cR;
  21. cR.Left = mForm.Left; cR.Top = mForm.Top; cR.Width = mForm.Width; cR.Height = mForm.Height;
  22. oldCtrl.Add(cR);//第一个为"窗体本身",只加入一次即可
  23. AddControl(mForm);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
  24. //this.WindowState = (System.Windows.Forms.FormWindowState)(2);//记录完控件的初始位置和大小后,再最大化
  25. //0 - Normalize , 1 - Minimize,2- Maximize
  26. }
  27. private void AddControl(Control ctl)
  28. {
  29. foreach (Control c in ctl.Controls)
  30. { //**放在这里,是先记录控件的子控件,后记录控件本身
  31. //if (c.Controls.Count > 0)
  32. // AddControl(c);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
  33. controlRect objCtrl;
  34. objCtrl.Left = c.Left; objCtrl.Top = c.Top; objCtrl.Width = c.Width; objCtrl.Height = c.Height;
  35. oldCtrl.Add(objCtrl);
  36. //**放在这里,是先记录控件本身,后记录控件的子控件
  37. if (c.Controls.Count > )
  38. AddControl(c);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
  39. }
  40. }
  41. //(3.2)控件自适应大小,
  42. public void controlAutoSize(Control mForm)
  43. {
  44. if (ctrlNo == )
  45. { //*如果在窗体的Form1_Load中,记录控件原始的大小和位置,正常没有问题,但要加入皮肤就会出现问题,因为有些控件如dataGridView的的子控件还没有完成,个数少
  46. //*要在窗体的Form1_SizeChanged中,第一次改变大小时,记录控件原始的大小和位置,这里所有控件的子控件都已经形成
  47. controlRect cR;
  48. // cR.Left = mForm.Left; cR.Top = mForm.Top; cR.Width = mForm.Width; cR.Height = mForm.Height;
  49. cR.Left = ; cR.Top = ; cR.Width = mForm.PreferredSize.Width; cR.Height = mForm.PreferredSize.Height;
  50.  
  51. oldCtrl.Add(cR);//第一个为"窗体本身",只加入一次即可
  52. AddControl(mForm);//窗体内其余控件可能嵌套其它控件(比如panel),故单独抽出以便递归调用
  53. }
  54. float wScale = (float)mForm.Width / (float)oldCtrl[].Width;//新旧窗体之间的比例,与最早的旧窗体
  55. float hScale = (float)mForm.Height / (float)oldCtrl[].Height;//.Height;
  56. ctrlNo = ;//进入=1,第0个为窗体本身,窗体内的控件,从序号1开始
  57. AutoScaleControl(mForm, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
  58. }
  59. private void AutoScaleControl(Control ctl, float wScale, float hScale)
  60. {
  61. int ctrLeft0, ctrTop0, ctrWidth0, ctrHeight0;
  62. //int ctrlNo = 1;//第1个是窗体自身的 Left,Top,Width,Height,所以窗体控件从ctrlNo=1开始
  63. foreach (Control c in ctl.Controls)
  64. { //**放在这里,是先缩放控件的子控件,后缩放控件本身
  65. //if (c.Controls.Count > 0)
  66. // AutoScaleControl(c, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
  67. ctrLeft0 = oldCtrl[ctrlNo].Left;
  68. ctrTop0 = oldCtrl[ctrlNo].Top;
  69. ctrWidth0 = oldCtrl[ctrlNo].Width;
  70. ctrHeight0 = oldCtrl[ctrlNo].Height;
  71. //c.Left = (int)((ctrLeft0 - wLeft0) * wScale) + wLeft1;//新旧控件之间的线性比例
  72. //c.Top = (int)((ctrTop0 - wTop0) * h) + wTop1;
  73. c.Left = (int)((ctrLeft0) * wScale);//新旧控件之间的线性比例。控件位置只相对于窗体,所以不能加 + wLeft1
  74. c.Top = (int)((ctrTop0) * hScale);//
  75. c.Width = (int)(ctrWidth0 * wScale);//只与最初的大小相关,所以不能与现在的宽度相乘 (int)(c.Width * w);
  76. c.Height = (int)(ctrHeight0 * hScale);//
  77. ctrlNo++;//累加序号
  78. //**放在这里,是先缩放控件本身,后缩放控件的子控件
  79. if (c.Controls.Count > )
  80. AutoScaleControl(c, wScale, hScale);//窗体内其余控件还可能嵌套控件(比如panel),要单独抽出,因为要递归调用
  81.  
  82. if (ctl is DataGridView)
  83. {
  84. DataGridView dgv = ctl as DataGridView;
  85. Cursor.Current = Cursors.WaitCursor;
  86.  
  87. int widths = ;
  88. for (int i = ; i < dgv.Columns.Count; i++)
  89. {
  90. dgv.AutoResizeColumn(i, DataGridViewAutoSizeColumnMode.AllCells); // 自动调整列宽
  91. widths += dgv.Columns[i].Width; // 计算调整列后单元列的宽度和
  92. }
  93. if (widths >= ctl.Size.Width) // 如果调整列的宽度大于设定列宽
  94. dgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.DisplayedCells; // 调整列的模式 自动
  95. else
  96. dgv.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill; // 如果小于 则填充
  97.  
  98. Cursor.Current = Cursors.Default;
  99. }
  100. }
  101.  
  102. }
  103. }
  1. private readonly AutoSizeFormClass asc = new AutoSizeFormClass();
  2. #region Override Functions
  3. /// <summary>
  4. /// OnLoad
  5. /// </summary>
  6. /// <param name="e"></param>
  7. protected override void OnLoad(EventArgs e)
  8. {
  9. base.OnLoad(e);
  10. DataBinding();
  11.  
  12. asc.controllInitializeSize(this);
  13. SizeChanged += _SizeChanged;
  14. int x = (SystemInformation.WorkingArea.Width - Size.Width) / ;
  15. int y = (SystemInformation.WorkingArea.Height - Size.Height) / ;
  16. StartPosition = FormStartPosition.Manual; //窗体的位置由Location属性决定
  17. Location = (Point)new Size(x, y); //窗体的起始位置为(x,y)
  18. }
  19. private void _SizeChanged(object sender, EventArgs e)
  20. {
  21. asc.controlAutoSize(this);
  22. }
  23. /// <summary>
  24. /// OnClosed
  25. /// </summary>
  26. /// <param name="e"></param>
  27. protected override void OnClosed(EventArgs e)
  28. {
  29. base.OnClosed(e);
  30. }

winfrom窗体自适应的更多相关文章

  1. Delphi:窗体自适应屏幕分辨率的改进

    在窗体依据屏幕分辨率自适应调整尺度方面,昨天的工作可以说是一个突破点.昨天的工作找到了长期以来我的原有方案的问题所在,这是非常关键的.但是昨天晚上的解决方案并不完美,今天的这个才是比较完美的解决版. ...

  2. WPF之路四:窗体自适应

    下面我来举个例子说明如何用Grid或DockPanel来实现自适应窗体. 让我们新建一个WPF工程,完成后我们打开对应的XAML文件,可以看到VS已经自动添加了<Grid></Gri ...

  3. winfrom窗体加载控制台程序,可以自定义输出语句颜色

    winfrom窗体加载控制台程序,可以自定方输出语句颜色,如下图所示 怎么实现的此功能,网上有大把的方法,我这里已经把方法打包成了一个类,只需要引用调用就可以使用了,写的比较粗糙,如有发现需要改进的地 ...

  4. winfrom窗体中嵌套WPF控件

    前言 本文主要介绍如何在winfrom窗体中嵌套WPF控件, 一来是自己记录一下,而来希望能对有需要的朋友提供实现思路. 如有错误请指出...下面进入正题... -1.前期准备 准备一个建立好的win ...

  5. Winfrom窗体无法关闭问题--检查是否存在重写

    问题描述: Winfrom窗体无法关闭问题----点击关闭/最大/最小化无法正常相应. 问题来源: 老版本的程序要求使用无边框的Form窗体(实现功能——设置为无边框窗体并重写窗体的关闭.最大.最小化 ...

  6. delphi 窗体自适应屏幕分辨率

    delphi 窗体自适应屏幕分辨率 这是个困惑我很长时间的问题,到今天终于得到解决了. 话说Delphi有个很强的窗体设计器,这一点让VC粉丝垂涎三尺而不可得.但是,Delphi里设计的窗体并没有自动 ...

  7. WinForm窗体自适应分辨率

    我们自己编写程序的界面,会遇到各种屏幕分辨率,只有自适应才能显的美观.实际上,做到这点也很简单,就是首先记录窗体和它上面控件的初始位置和大小,当窗体改变比例时,其控件的位置和大小也按此比例变化即可.因 ...

  8. Delphi 实现窗体自适应调整尺寸以适应不同屏幕分辩率的显示问题

    给你一段代码,网上转的:unit uMyClassHelpers;//实现窗体自适应调整尺寸以适应不同屏幕分辩率的显示问题.//        陈小斌,2012年3月5日 interface Uses ...

  9. 【2017-12-06】winfrom 窗体自启最大化,控件自适应

    先将窗体windowstate属性设置为Maximized public partial class Form1 : Form { public Form1() { InitializeCompone ...

随机推荐

  1. 《Mysql - SQL优化》

    一:在查询语句时,应该注意的优化问题 - SELECT语句务必指明字段名称 - SELECT * 会增加很多不必要的消耗(CPU.IO.内存.网络带宽) - 同时会让 Mysql 优化器无法优化 -  ...

  2. Django——关于项目开发遇到的一些小技巧

    目录 头像图片 js获取网站信息 js获取前端信息 Dj获取刚写入的数据的信息 js跳转新链接 头像图片对象的显示 在做到根据登陆ID决定用户头像的时候,加载静态文件的{% static ‘xxxxx ...

  3. springboot项目在IDEA根据不同的开发人员读取不同的配置文件

    IDEA启动项目打开项目的配置文件,修改Program argument为--spring.profiles.active=developerName启动项目,即可 命令行方式启动项目 java -j ...

  4. ActiveMQ 简单应用

    ActiveMQ简单应用到复杂的订单模块,提高前台的访问速度. 一.当提交订单后,发送消息给ActiveMQ. @Service public class JmsSend { private stat ...

  5. 使用RabbitMQ实现分布式事务

    RabbitMQ解决分布式事务思路: 案例: 经典案例,以目前流行点外卖的案例,用户下单后,调用订单服务,让后订单服务调用派单系统通知送外卖人员送单,这时候订单系统与派单系统采用MQ异步通讯. Rab ...

  6. (八) Hibernate中的Session以及事务

    HibernateUtil.getSessionFactory().getCurrentSession() 和HibernateUtil.getSession() 的区别: 1.异:getCurren ...

  7. opengl 笔记

    1. 本函数可以禁用多边形正面或背面上的光照.阴影和颜色计算及操作,消除不必要的渲染计算是因为无论对象如何进行旋转或变换,都不会看到多边形的背面.用GL_CULL_FACE参数调用glEnable和g ...

  8. ligerui.grid.extend.rowSpan

    扩展LigerUI的Grid中的相同列合并行功能,代码如下:$.extend($.ligerui.controls.Grid.prototype, { _getHtmlFromData:functio ...

  9. Unity 宽度适配 NGUI

    这是很久之前写的一篇Note,现在移到Blog上来,可能有些参数,NGUI插件等等不和现在版本相同.不过大概的思路应该不会错. ps: 可能有部分內容是摘抄自其他作者,没办法考证了,如有请务必联系我. ...

  10. JavaScript Drum kit

    用 JavaScript 实现网页鼓乐器,相关的初始代码在 JavaScript30 官网和 GitHub 上已经存在.我把 sound 文件夹下的音频全部替换掉了,一些相关解释也直接在注释中标明. ...