博客
关于我
布局器
阅读量:584 次
发布时间:2019-03-11

本文共 2248 字,大约阅读时间需要 7 分钟。

布 局 器 布局器

1.布局器

布局器LayoutEngine:负责子控件的布局

默认地,一个Form或Panel 都自带了一个布局器

在窗口改变大小时,由窗口的布局器来负责调整布局


SimpleLayoutPanel :自定义一个Panel,并自己实现一个LayoutEngine

using System;using System.Collections.Generic;using System.Drawing;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Windows.Forms;using System.Windows.Forms.Layout;namespace FormApp0601{       // 自定义面板    class SimpleLayoutPanel : Panel    {           // 布局器        private LayoutEngine layoutEngine = new SimpleLayoutEngine();                public override LayoutEngine LayoutEngine        {               get            {                                   return layoutEngine;            }        }    }    // 自定义布局器    class SimpleLayoutEngine :  LayoutEngine    {           public override bool Layout(            object container,            LayoutEventArgs layoutEventArgs)        {               // 容器            SimpleLayoutPanel parent = (SimpleLayoutPanel)container;            int w = parent.Width;            int h = parent.Height;            // 去除Padding            int x = parent.Padding.Left;            int y = parent.Padding.Top;            w -= (parent.Padding.Left + parent.Padding.Right);            h -= (parent.Padding.Top + parent.Padding.Bottom);            int gap = 2;            foreach (Control c in parent.Controls)            {                   c.Location = new Point(x, y);                c.Size = new Size(w, c.PreferredSize.Height);                y += c.Size.Height;                y += gap;            }                       return false;        }    }}

自定义布局器的使用步骤:

1工具I选项,Windows窗体设计器I常规自动填充工具箱:设为True2添加自定义Panel或Control的类 3生成解决方案F74重新打开Form1.cs,在工具箱界面可以看到自己的控件

在这里插入图片描述

在这里插入图片描述


2.FlowLayoutPanel

FlowLayoutPanel,流式布局

子控件依次排列,一行排满之后换行继续排

在这里插入图片描述

在这里插入图片描述


1布局的嵌套

Panel本身也是控件,也有Anchor/Dock属性

2属性的设置

试着设一下Padding等属性

3控件的选择

右键,选择控件或该控件所在的面板
在这里插入图片描述

在这里插入图片描述


3.TableLayoutPanel

TableLayoutPanel,表格布局

以表格的形式进行布局

在这里插入图片描述

演示:使用TableLayoutPanel来布局界面

1 添加TableLayoutPanel,停靠在上方2 添加Button , TextBox到表格,设置列的宽度3 设置TextBox的Dock,填满单元格4 添加PictureBox,停靠在中央

表格中的控件也可以设置Dock属性

如何利用Dock属性,其规则是由布局器决定的

4.MjDockLayout

比如,默认的Dock停靠布局并不好用

演示对比:
第一种情况:先Left后 Fill
第二种情况:先Fill后Left
最终的布局效果依赖于控件添加的顺序,非常不方便


1 添加Mj.Winform.DockLayout.cs到项目2 重新生成项目3 在工具箱里找到MjDockLayout,添加到布局4 在面板中添加子控件,设置Dock5 设置MjDockLayout.DockFlags属性

转载地址:http://vzdtz.baihongyu.com/

你可能感兴趣的文章
Vue3+elementplus实现图片上传下载(最强实践)
查看>>
Node-RED中将CSV数据写入txt文件并从文件中读取解析数据
查看>>
Node-RED中建立TCP服务端和客户端
查看>>
Node-RED中建立Websocket客户端连接
查看>>
Node-RED中建立静态网页和动态网页内容
查看>>
Vue3+Element-ul学生管理系统(第二十二课)
查看>>
Node-RED中怎样让网站返回JSON数据
查看>>
Node-RED中根据HTML文件建立Web网站
查看>>
Node-RED中解析高德地图天气api的json数据显示天气仪表盘
查看>>
Node-RED中连接Mysql数据库并实现增删改查的操作
查看>>
Node-RED中通过node-red-ui-webcam节点实现访问摄像头并截取照片预览
查看>>
Node-RED中配置周期性执行、指定时间阶段执行、指定时间执行事件
查看>>
Node-RED安装图形化节点dashboard实现订阅mqtt主题并在仪表盘中显示温度
查看>>
Node-RED怎样导出导入流程为json文件
查看>>
Node-RED简介与Windows上安装、启动和运行示例
查看>>
Node-RED订阅MQTT主题并调试数据
查看>>