W04合理布局,是程序界面构造的起点,Grid控件会助你一臂之力
xsobi 2024-11-23 10:46 21 浏览
Grid网格
一、概述
程序的一个窗口,就像一片空旷的土地,你拿这片空地干什么?是盖房?还是种地?不管干什么,我们所要做的第一件事通常都是规划和布局,Grid(网格)控件就是WPF中基本的布局工具,它将程序窗口的用户区用虚拟或真实的网格线划分成由若干行和若干列组成的矩形区域,在这些矩形的区域里,我们可以放置其它的控件,从而构造出合理的布局。
二、具体来讲,我们可以通过Grid控件的以下属性来定义网格
1. RowDifinitions行定义集合,用它来包含若干个行定义
<Grid.RowDefinitions>…</Grid.RowDefinitions>
2. RowDefinition行定义,定义某一行的特征<RowDefinition/>,每一个标签定义一行。其属性有:
(1)Height行高,语法格式为Height="xxx"
(2)MaxHeight最大行高
(3)MinHeight最小行高
<RowDefinition Height="xxx"/>
3. ColumnDifinitions列定义集合,用它来包含若干列
<ColumnDifinitions>…</ ColumnDifinitions>
4. ColumnDefinition列定义,定义某一列的特征,每一个标签定义一列。其属性有:
(1)Width列宽
(2)MaxWidth最大列宽
(3)MinWidth最小列宽
<ColumnDefinition Width="100"/>
5. ShowGridLines="True" Grid面板网格线默认被设计成不可见的,但可将Grid.ShowGridLines属性设置为True,使得网格线得以显示,从而更清晰的观察Grid面板,方便调试,可以更准确地控制Grid面板如何选择列宽和行高。
三、行高和列宽的定义方式
1.定义语法
(1)行高定义——用属性Height="xxx"中的xxx来定义
<RowDefinition Height="xxx"/>
(2)列宽定义——用属性Width="xxx"中的xxx来定义
<ColumnDefinition Width="100"/>
2.定义方式
Grid的行高和列宽可采用固定、自动、按比列三种方式定义
(1)第一种,固定行高或列宽,——xxx值为一个确定的数字,使用设备无关单位准确地设置尺寸,就是给一个实际的数字,但通常将此值指定为整数。这是最无用的策略,因为这种策略不够灵活,难以适应内容大小和容器大小的改变,而且难以处理本地化。
(2)第二种,自动行高或列宽,——xxx值为Auto,就是自动取放置在网格中的控件的高度为行的高度,或取控件的宽度为列的宽度。所需的最小值,每行和每列的尺寸刚好满足需要,这是最有用的尺寸设置方式。
(3)第三种,按比例设置行高或列宽,——xxx值为*或N*(其中N为整数),所有*前面的整数之和Z表示将一行的全部高度或一列的全部宽度分成Z分,每一行所占的高度即是Z分之几;例如:网格若有两行,两行的高度都是*,那么两行将平分整个高度;一个2*,一个*,则前者占剩余全部宽度的2/3,后者占1/3;依此类推,这是对所有行和列的标准设置。
通常,为了获得最大的灵活性,可混合使用这三种尺寸设置方式。例如,创建几个自动设置尺寸的行,然后通过按比例设置尺寸的方式让最后的一行或两行充满剩余的空间,这通常是很有用的。
例(1):设置100设备无关单位的绝对宽度:
<ColumnDefinition Width="100"></ColumnDefinition>
例(2)使用自动尺寸设置方式,需要使用Auto值
<ColumnDefinition Width="Auto"></ColumnDefinition>
例(3)使用按比例尺寸设置方式,需要使用星号(*)
<ColumnDefinition Width="*"></ColumnDefinition>
四、举个例子,我们可以通过以下代码构造出一个三行三列的网格
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition/>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition/>
<RowDefinition/>
<RowDefinition/>
</Grid.RowDefinitions>
</Grid>
五、附加属性,合理放置其它控件
网格画好了,那其它控件该如何放置呢?这就要用到Grid控件的两个附加属性。所谓附加属性就是网格附加在放置于其内部的控件上的属性,用以表示该控件在整个网格中的位置。“附加属性”不好理解?其实很简单,附加属性就像我们看电影时或坐火车时的座位号一样,你买票之前,你是没有座位的,你买了票了,票上就写明了座位号,你对号入座就可以了。以下是几个附加属性。
1. Grid.Row="xxx",其中xxx为控件所在行的索引号,第一行为0,第二行为1,以此类推。
2. Grid.Column="xxx",其中xxx为控件所在列的索引号,第一列为0,第二列为1,以此类推。
3. Grid.RowSpan="2"我要占两行
4. Grid.ColumnSpan=“3”我要占三列
好了,规划好了+布局,你就可以摆放控件,构造你漂亮的用户界面了。
相关推荐
- 推荐几款 Webshell 查杀工具 PHP、Python、JSP、ASP、JS、HTML、Apk
-
Webshell会严重威胁到网站的安全性,webshell木马可以任意修改网站文件内容,查看系统环境、执行脚本、提权等等,甚至可以严重威胁数据库的安全。作为一名站长,定期检查网站文件安全是必不可少的...
- Visual Studio Code安装C#开发工具包并编写ASP.NET Core Web应用
-
前言前段时间微软发布了适用于VSCode的C#开发工具包(注意目前该包还属于预发布状态但是可以正常使用),因为之前看过网上的一些使用VSCode搭建.NETCore环境的教程看着还挺复杂的就一...
- DevExpress Demo示例展示:ASP.NET MVC报表无与伦比的设计时体验
-
DevExpressASP.NETMVCReporting原生集成DevExpressASP.NETMVC扩展以及无与伦比的设计时生产力。下面几个典型示例展示了它强大的设计时功能,Web报...
- 在ubuntu下新建asp.net core项目(ubuntu创建swap)
-
本文一步步讲述在ubuntu下用visualstudiocode创建asp.netcore项目的过程。step1:环境操作系统:virtualbox下安装的lubuntu。请不要开启“硬件...
- Asp.net常用方法及request和response-a
-
asp.net教程asp.net常用方法:1、Request.UrlReferrer请求的来源,可以根据这个判断从百度搜的哪个关键词、防下载盗链、防图片盗链,可以伪造(比如迅雷)。(使用全局一般处理...
- 「B/S端开发」DevExtreme初级入门教程 - ASP.NET MVC 5控件简介
-
欢迎阅读了解DevExtremeASP.NETMVC5控件有关的文档!DevExtremeCompleteSubscription官方最新版免费下载试用,历史版本下载,在线文档和帮助文件下...
- 微软跨平台开源.Net Core与ASP.Net已可用于生产环境
-
周三在举行Connect2015的同时,微软升级了.NetCore和ASP.Net,开发者可以开始在生产环境使用微软开源的.NetCore跨平台框架和ASP.NetWeb平台。微软发布了.Net...
- 用ASP生成Excel数据三种方法(asp生成word)
-
可能是将一个html表格变成MicrosoftExcel格式的最快方法。ContentType属性通知浏览器数据要被格式化为何种格式,在这里我们要的格式是MicrosoftExcel。当浏...
- 个人web开发我选Asp.net core,你选谁?PHP?还是JSP?
-
现在很多公司都会选用PHP,JSP来开发,但是现在Asp.netcore已经今非昔比了。今天微软金牌合作伙伴51aspx来分享一些关于.Net的那点事。.Net以前是不开源的,需要收费,有着各种版权...
- 创建第一个ASP.NET Core WebService程序
-
要创建第一个ASP.NETCoreWebService程序,可以按照以下步骤进行:1、安装.NETCoreSDK:首先,确保已在计算机上安装了最新版本的.NETCoreSDK。可以从Mic...
- 网站收录,网站收录方法技巧,网站收录入口(图文教程)
-
网站收录,是网站参与排名的前提,搜索引擎会先收录网站到自己的索引库里,然后根据算法计算出排名结果。也就是说,搜索引擎不收录的网站没有任何获得排名的机会。所以,我们需要关注自身网站收录情况。网站收录指的...
- 黑客通过Kali Linux设置一个钓鱼网站原来这么简单
-
一、背景介绍钓鱼网站是指欺骗用户的虚假网站。“钓鱼网站”的页面与真实网站界面基本一致,欺骗消费者或者窃取访问者提交的账号和密码信息。钓鱼网站一般只有一个或几个页面,和真实网站差别细微。钓鱼网站是互联网...
- 快速将网站从HTTP升级到HTTPS教程
-
在当今社会,每个人都离不开互联网,网络的安全性变得越来越重要,将网站从HTTP协议升级到HTTPS协议已成为保护用户数据安全和提高网站信任度的必要步骤,HTTPS不仅加密了用户与服务器之间的数据传输,...
- 从学习硬件知识到选电脑配置再到电脑组装教程及系统安装-导航篇
-
对于准备想要装机的小白来说,可能会在网上找各种关于硬件知识文章,或者直接找适合自己的组装电脑配置清单,电脑组装教程以及系统安装教程等,但其实装机之家网站上有着大量关于这类文章,就是由于文章过多,导致了...
- 10个顶级的office学习网站,5天让你菜鸟变大神,月薪过万不用愁
-
现在有很多小伙伴在工作的时候,都需要用到各种office办公软件。但是对于很多职场小白来说,想要很好的掌握office真的不是一件简单的事情。别担心,今天小编将推荐10个优质的office学习网站给大...
- 一周热门
- 最近发表
-
- 推荐几款 Webshell 查杀工具 PHP、Python、JSP、ASP、JS、HTML、Apk
- Visual Studio Code安装C#开发工具包并编写ASP.NET Core Web应用
- DevExpress Demo示例展示:ASP.NET MVC报表无与伦比的设计时体验
- 在ubuntu下新建asp.net core项目(ubuntu创建swap)
- Asp.net常用方法及request和response-a
- 「B/S端开发」DevExtreme初级入门教程 - ASP.NET MVC 5控件简介
- 微软跨平台开源.Net Core与ASP.Net已可用于生产环境
- 用ASP生成Excel数据三种方法(asp生成word)
- 个人web开发我选Asp.net core,你选谁?PHP?还是JSP?
- 创建第一个ASP.NET Core WebService程序
- 标签列表
-
- grid 设置 (58)
- 移位运算 (48)
- not specified (45)
- 导航栏 (58)
- context xml (46)
- scroll (43)
- dedecms模版 (53)
- c 视频教程下载 (33)
- listview排序 (33)
- characterencodingfilter (33)
- getmonth (34)
- label换行 (33)
- android studio 3 0 (34)
- html转js (35)
- 索引的作用 (33)
- checkedlistbox (34)
- xmlhttp (35)
- mysql更改密码 (34)
- 权限777 (33)
- htmlposition (33)
- 学校网站模板 (34)
- textarea换行 (34)
- 轮播 (34)
- asp net三层架构 (38)
- bash (34)