博客
关于我
布局器
阅读量: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/

你可能感兴趣的文章
Nodejs中搭建一个静态Web服务器,通过读取文件获取响应类型
查看>>
Nodejs中的fs模块的使用
查看>>
NodeJS使用淘宝npm镜像站的各种姿势
查看>>
NodeJs入门知识
查看>>
nodejs包管理工具对比:npm、Yarn、cnpm、npx
查看>>
NodeJs单元测试之 API性能测试
查看>>
nodejs图片转换字节保存
查看>>
nodejs在Liunx上的部署生产方式-PM2
查看>>
nodejs基于art-template模板引擎生成
查看>>
nodejs字符与字节之间的转换
查看>>
NodeJs学习笔记001--npm换源
查看>>
NodeJs学习笔记002--npm常用命令详解
查看>>
nodejs学习笔记一——nodejs安装
查看>>
vue3+Element-plus icon图标无法显示的问题(已解决)
查看>>
NodeJS实现跨域的方法( 4种 )
查看>>
nodejs封装http请求
查看>>
nodejs常用组件
查看>>
nodejs开发公众号报错 40164,白名单配置找不到,竟然是这个原因
查看>>
Nodejs异步回调的处理方法总结
查看>>
NodeJS报错 Fatal error: ENOSPC: System limit for number of file watchers reached, watch ‘...path...‘
查看>>