首页 > 编程语言 >c# WPF 布局控件

c# WPF 布局控件

时间:2024-02-19 15:13:23浏览次数:40  
标签:控件 元素 c# Demo 布局 child WPF Size

c# WPF 布局控件

c# WPF 布局控件

风雨飘潇 风雨飘潇 有鼻子有眼,普通路人一个   3 人赞同了该文章

一、概论

  WPF是继MFC和Winform后,下一代Windows 桌面应用程序的技术。其核心是一个与分辨率无关并且基于向量的程序引擎,以在现代图形硬件的优势下,实现更优质的用户客户端软件。

  WPF的布局控件是继承于System.Windows.Controls.Panel这个类的,本文我们主要举例说明,在Panel基类下的几个常用的窗口布局控件。

二、 Canvas

  Canvas面板是最轻量级的布局控件,元素按照默认大小显示在左上角,溢出的内容则会显示在Canvas外(可以将ClipToBounds属性设置为true来裁剪溢出内容)。下面是使用Canvas面板的XAML代码。

    <Canvas Background="LightGray" Margin="10,10,10,64" >
        <Rectangle Name="rect"  Width="200" Height="200" Fill="#FF1BEA41"/>
        <Rectangle  Width="100" Height="300" Fill="#FF1131C3" Canvas.Left="321" Canvas.Top="100"/>
        <Button Content="Button" Canvas.Left="499" Canvas.Top="25" Width="152" Height="37"/>
    </Canvas>

效果如下:

Canvas Demo

三、DockPanel

  DockPanel中,可以使子元素通过锚点的形式进行排列,类似于WinForm中Dock属性的功能。

    <DockPanel Margin="10" LastChildFill="True">
        <Button Content="Top" DockPanel.Dock="Top"/>
        <Button Content="Left" DockPanel.Dock="Left"/>
        <Button Content="Right" DockPanel.Dock="Right"/>
        <Button Content="Bottom" DockPanel.Dock="Bottom"/>
        <Button Content="Btn1"/>
        <Button Content="Btn2"/>
        <Button Content="Btn3"/>
        <Button/>
    </DockPanel>

  效果如下:

 

DockPanel Demo

四、Grid

  Grid使用类似表格的布局方式,可以指定行列数量,以及分配对应大小。控件中的子元素会附加特定属性,由用户指定该子元素所在的行列位置,横跨方式等等。Grid 控件使用灵活,适合子元素多、布局复杂的场景:

    <Grid Width="Auto" Height="Auto">
            <Grid.RowDefinitions>
                <RowDefinition/> 
                <RowDefinition/> 
            </Grid.RowDefinitions> 
            <Grid.ColumnDefinitions>
                <ColumnDefinition Width="100"/> //固定值
                <ColumnDefinition Width="120"/> 
                <ColumnDefinition Width="*"/> //比例值,去除固定宽度后按比例分到剩余空间的1/3
                <ColumnDefinition Width="2*"/> 
            </Grid.ColumnDefinitions>
        <Button Content="Btn1" Grid.RowSpan="2"/>
        <Button Content="Btn2" Grid.Column="1" Grid.ColumnSpan="2"/>
        <Button Content="Btn3" Grid.Row="1" Grid.Column="2"/>
        <Button Content="Btn4" Grid.Row="1" Grid.Column="3"/>
    </Grid> 

效果如下:

 

Grid Demo

五、StackPanel

  StackPanel控件是将子元素按照单行或单列的方式进行堆叠,可以通过Orientation参数,指定排列方向。下面对子元素设置不同参数进行展示:

   <StackPanel Margin="10,10,10,10" Background="Azure">
        <Button Content="Button"/>
        <Button Content="Button" Width="200"/>
        <Button Content="Button" Height="50"/>
        <Button Content="Button" Margin="200,0,0,0" />
        <Button Content="Button" Width="200" Margin="200,0,0,0" />
    </StackPanel>

效果如下:

StackPanel Demo

六、WrapPanel

  WrapPanel控件按从左到右的顺序位置定位子元素,在包含框的边缘处将内容切换到下一行。 后续排序按照从上至下或从右至左的顺序进行,具体取决于方向Orientation属性的值。控件内部子元素布局会跟随控件大小变化自动调整,一般WrapPanel控件只用在小范围布局,控件大小也保持固定。

    <WrapPanel Margin="10" Background="Azure">
        <Button Content="Button" Height="50" Width="100"/>
        <Button Content="Button" VerticalAlignment="Top"/>
        <Button Content="Button" VerticalAlignment="Center"/>
        <Button Content="Button" VerticalAlignment="Bottom"/>
        <Button Content="Button"/>
        <Button Content="Button" Width="100"/>
        <Button Content="Button" Height="30"  VerticalAlignment="Top"/>
        <Button Content="Button" VerticalAlignment="Center"/>
        <Button Content="Button" VerticalAlignment="Bottom"/>
        <Button Content="Button"/>
    </WrapPanel>

  效果显示,单行高度由其中子元素高度属性最大值决定,并同时影响同列其他子元素的排列位置:

WrapPanel Demo

七、UniformGrid

  UniformGrid是Grid简化版本,不需要预先定义行和列,每个单元格具有相同大小。可以通过简单设置Rows和Columns属性来设置整体布局需求,或使用默认值0,使控件自动调整合适的布局。下面是添加四个元素后,控件自动分割为2*2的表格:

    <UniformGrid>
        <Button Content="Button" Width="100" Height="50"/>
        <Button Content="Button" />
        <Button Content="Button" />
        <Button Content="Button" />
   </UniformGrid>
UniformGrid Demo

将子元素数量增加,控件布局自动调整:

    <UniformGrid>
        <Button Content="Button" Width="100" Height="50"/>
        <Button Content="Button" />
        <Button Content="Button" />
        <Button Content="Button" />
        <Button Content="Button" />
    </UniformGrid>
UniformGrid Demo

八、ScrollViewer

ScrollViewer控件可以方便地使应用程序中的内容具备滚动功能:

   <ScrollViewer HorizontalScrollBarVisibility="Visible" VerticalScrollBarVisibility="Auto">
      <Rectangle Width="500" Height="800"/>
   </ScrollViewer>

  效果如下:

ScrollViewer Demo

九、自定义布局控件

  要实现自定义布局控件,需要继承Panel类并重写MeasureOverride和ArrangeOverride方法。首先,自定义一个用户类:

using System.Windows;
using System.Windows.Controls;

namespace TestClass
{
    public class TestPanel : Panel
    
        public TestPanel(): base() {}
        // 重写默认的Measure方法
        protected override Size MeasureOverride(Size availableSize)
        {
            Size v_panelDesiredSize = new Size();
            foreach (UIElement v_child in this.InternalChildren)
            {
                v_child.Measure(availableSize); 
                v_panelDesiredSize.Width += v_child.DesiredSize.Width;
                v_panelDesiredSize.Height += v_child.DesiredSize.Height;
            }
            return v_panelDesiredSize;
        }
        // 重写默认的Arrange方法
        protected override Size ArrangeOverride(Size finalSize)
        {
            double v_x = 10;
            double v_y = 10;
            foreach (UIElement v_child in this.InternalChildren)
            {
                v_child.Arrange(new Rect(new Point(v_x, v_y), new Size(200, v_child.DesiredSize.Height)));
                v_y += v_child.RenderSize.Height + 5;
                v_x += 5;
            }
            return finalSize;
        }
    } 
}

  添加自定义控件的程序集,及如下代码:

<Window x:Class="WpfApp2.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:mcontrol="clr-namespace:TestClass"
        xmlns:local="clr-namespace:WpfApp2"
        mc:Ignorable="d"
        Title="MainWindow" Height="277.5" Width="542">
    <mcontrol:TestPanel Margin="0,0,266,143">
        <Button Content="Button"/>
        <Button Content="Button"/>
        <Button Content="Button"/>
    </mcontrol:TestPanel>
</Window>

  效果如下:

自定义布局控件 编辑于 2023-10-20 11:53・IP 属地天津

标签:控件,元素,c#,Demo,布局,child,WPF,Size
From: https://www.cnblogs.com/sexintercourse/p/18021132

相关文章

  • C# 12 中的新增功能
    C#12中的新增功能项目2023/11/2011个参与者反馈 本文内容主构造函数集合表达式refreadonly参数默认Lambda参数显示另外5个C#12包括以下新增功能。可以使用最新的 VisualStudio2022 版本或 .NET8SDK 尝试这些功能。主构造函数 -在Vi......
  • Office Online Server Windows Server 2016 部署
    一、准备“武器”本文是通过虚拟机搭建OOS测试环境的,4567是3的前提,武器提取le731、VMWareWorkstation17Player2、WindowsServer2016镜像(需要OfficeOnlineServer2017年4月或更高版本)3、OfficeOnlineServer2016(简称OOS)4、NETFramework4.5.2(NDP452-KB2901......
  • itchat保存接收到的图片
    importitchatfromitchat.contentimportTEXT,MAP,CARD,NOTE,SHARING,PICTURE,RECORDING,ATTACHMENT,VIDEO,FRIENDS,SYSTEM#下载文件到本地defdownload_files(msg):msg.download("C:\\360demo\\"+msg['FileName'])#itchat.send......
  • 2024-02-18-物联网C语言(8-结构体、共用体、枚举)
    8.结构体、共用体、枚举8.1结构体的概念和定义8.1.1基本概述构造类型:不是基本类型的数据结构也不是指针,它是若干个相同或不同类型的数据构成的集合。常用的构造类型有数组、结构体、共用体。数组用于保存多个相同类型的数据结构体用于保存多个不同类型的数据8.1.2概......
  • 设置使用Pycharm创建py文件时,自动在文件里添加固定格式的注释
    当创建新的py文件时,希望文件头能够生成注释具体做法:1.打开pycharm,找到setting选项 2.点击setting,选择左侧fileandcodetemplates,然后点击pythonscript,在右侧空白部分填入所需的模版。点击apply、点击ok即可。  3.模版案例 #-*-coding:utf-8-*-#************......
  • VC++ 中 CT2A CA2T 两个宏进行字符串转换简单测试
    #include"afxwin.h"#include<iostream>usingnamespacestd;intmain(){CStringcs=_T("西游记");AfxMessageBox(_T("CString:")+cs);//CString转ACSIICT2Aa_str(cs);stringstd_str(a_str);......
  • code: 'ERR_OSSL_EVP_UNSUPPORTED' 报错解决
    报错:Error:error:0308010C:digitalenveloperoutines::unsupportedatnewHash(node:internal/crypto/hash:69:19)atObject.createHash(node:crypto:133:10)atBulkUpdateDecorator.hashFactory(D:\WzProject\wz-middle-ground-frontend\node_module......
  • 唯一客服系统:Golang开发客服系统源码,支持网页,H5,APP,微信小程序公众号等接入,商家有PC端
    本系统采用GolangGin框架+GORM+MySQL+Vue+ElementUI开发的独立高性能在线客服系统。客服系统访客端支持PC端、移动端、小程序、公众号中接入客服,利用超链接、网页内嵌、二维码、定制对接等方式让网上所有通道都可以快速通过本系统联系到商家。 服务端可编译为二进制程序包,无......
  • KY78 最大上升子序列和C++
    这个解决问题的思路使用动态规划,即用已知状态去得到未知状态。思路逻辑是这样sum[i]记录以A[i]为末上升子序列的和的最大值然后从j从0-i-1遍历如果A[j]<A[i]那么sum[i]=sum[j]+A[i];然后找出sum[i]中的的最大值,就是以A[i]为末上升子序列的和的最大值。这样就实现了从前......
  • css样式相关代码记录
    element样式穿透:::v-deepposition属性值有static、relative、absolute、fixed、sticky。static:该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。relative:该关键字下,元素先放置在未添加定位时的位置,再在不改变页面布局的前提下调整元素位置(因此会......