博客
关于我
控件的布局
阅读量:588 次
发布时间:2019-03-11

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

控 件 的 布 局 控件的布局

1.控件的布局

控件的布局:当窗口中有多个控件时,如何决定每个控件的位置和大小。

布局的方式:

1 可视化布局:在设计器里拖放操作2 手工布局:用代码计算每个控件的位置3 使用布局器:用布局器自动布局

演示:添加几个控件,进行可视化布局

按钮, Button文本框,TextBox图片框,PictureBox

在这里插入图片描述

当窗口改变大小时,布局并不能够自动适应所以,此种布局只适用于窗口大小固定不变的情况

在这里插入图片描述

2.手工布局

手工布局:用代码计算每个控件的位置

重写OnIayout方法

override void OnLayout (LayoutEventArgs levent){   }

当窗口大小改变时,会自动调用这个方法重新布局

演示:在窗口中添加几个控件,并实现手工布局。

其中,窗口的大小:
Size:窗口大小(含标题栏和边框)
ClientSize :仅窗口客户区的大小

using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using System.Drawing;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Windows.Forms;namespace WinForm基础3{       public partial class Form1 : Form    {           public Form1()        {               InitializeComponent();            this.timeField.AutoSize = false;        }        protected override void OnLayout(LayoutEventArgs levent)        {               // 1.调用父类的OnLayout(),不是必需的            base.OnLayout(levent);            // 2.获取窗口的大小ClientSize(仅客户区,不含标题栏)            int w = this.ClientSize.Width;            int h = this.ClientSize.Height;            // 3.计算每个控件的位置和大小            int yoff = 0;            yoff = 4;            this.timeField.Location = new Point(0, yoff);            this.timeField.Size = new Size(w - 80, 30);            this.button1.Location = new Point(w - 80, yoff);            this.button1.Size = new Size(80, 30);            yoff += 30;            yoff += 4;            this.pictureBox1.Location = new Point(0, yoff);            this.pictureBox1.Size = new Size(w, h - yoff - 4);        }        private void On_Test(object sender, EventArgs e)        {               string timeStr = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");            timeField.Text = timeStr;        }    }}

在这里插入图片描述

1 TextBox : AutoSize = false

否则它会自己计算所需的大小

2区分窗口的Size和 ClientSize

3窗口的自适应:当窗口大小变化时,会自动调用OnLayout()方法

3.Anchor

控件的两个通用的布局属性:

Anchor:锚定,将控件固定于某个位置Dock:停靠,将控件停靠在一侧或中央

演示:设置一个控件的 Anchor为Top l Right

当窗口大小改变时,该控件锚定于窗口的右上角
即,与父窗口的上边距Top和右边距 Right保持不变


在这里插入图片描述

在这里插入图片描述
1 锚定于左下角

  • Anchor =Left | Bottom

2 锚定于右下角

  • Anchor = Right | Bottom

3锚定于上边缘、水平拉伸

  • Anchor = Top l Left l Right

4锚定于上边缘、水平居中-水平居中

  • Anchor =Top l Left l Right

5拉伸

  • Anchor = Top l Right I Bottom l Left

6居中

  • 水平居中,垂直居中-Anchor: None

4.Dock

Dock:停靠,将控件停靠在一侧或中央

上 Top下 Bottom左 Left右 Right中 Fill无 None

演示:Panel,面板

1添加一个Panel,停靠在上侧2添加一个Panel,依靠在左侧3添加一个PictureBox,依靠在中央

依靠于左右两侧时,可以调整宽度;上下两侧时,可以调整高度。


在这里插入图片描述

当设置Dock属性时,Anchor属性无效

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

你可能感兴趣的文章
Webpack 基本环境搭建
查看>>
mysql5.7 安装版 表不能输入汉字解决方案
查看>>
MySQL5.7.18主从复制搭建(一主一从)
查看>>
MySQL5.7.19-win64安装启动
查看>>
mysql5.7.19安装图解_mysql5.7.19 winx64解压缩版安装配置教程
查看>>
MySQL5.7.37windows解压版的安装使用
查看>>
mysql5.7免费下载地址
查看>>
mysql5.7命令总结
查看>>
mysql5.7安装
查看>>
mysql5.7性能调优my.ini
查看>>
MySQL5.7新增Performance Schema表
查看>>
Mysql5.7深入学习 1.MySQL 5.7 中的新增功能
查看>>
Webpack 之 basic chunk graph
查看>>
Mysql5.7版本单机版my.cnf配置文件
查看>>
mysql5.7的安装和Navicat的安装
查看>>
mysql5.7示例数据库_Linux MySQL5.7多实例数据库配置
查看>>
Mysql8 数据库安装及主从配置 | Spring Cloud 2
查看>>
mysql8 配置文件配置group 问题 sql语句group不能使用报错解决 mysql8.X版本的my.cnf配置文件 my.cnf文件 能够使用的my.cnf配置文件
查看>>
MySQL8.0.29启动报错Different lower_case_table_names settings for server (‘0‘) and data dictionary (‘1‘)
查看>>
MYSQL8.0以上忘记root密码
查看>>