【WPF】03 动态生成控件

在这里插入图片描述

在这里插入图片描述

说明

今天记录一篇关于动态生成控件的方法,也是反复查了一些资料,逐步完善成自己需要的方法,感觉还是比较好用的。通过这个需求,在网上也找了一些资料,发现了一个开源图形UI组件HandyControl,觉得比较好,虽然暂时还没怎么用上,但安装完成后,确实美化了原来wpf的一些控件形状。
gtiee地址:https://gitee.com/handyorg/HandyControl

Nuget管理包安装
在这里插入图片描述

编码实现

直接上代码说明了,文章就不详细描述什么原理什么过程的,将来需要直接问大模型就好了。

动态添加RowDefinitions和ColumnDefinitions

首先,在XAML中,定义一个空的Grid,然后在代码后台(C#)中动态地向这个Grid添加RowDefinitions和ColumnDefinitions,以及相应的子控件(如TextBox)。

XAML部分:

<ScrollViewer VerticalScrollBarVisibility="Auto" Margin="20,10,0,0" Height="380" Width="750" HorizontalAlignment="Left" VerticalAlignment="Top">
    <Grid x:Name="myDynamicGrid" Margin="5,5,5,5">

        <!-- 初始时不添加任何行,通过代码动态添加 -->

    </Grid>
</ScrollViewer>

C#部分:

生成控件的部分

/// <summary>
/// 动态生成控件
/// </summary>
private void GenerateControls(int iRowsIndex)
{
   
   
    for (int i = 0; i < iRowsIndex; i++)
    {
   
   
        RowDefinition rowDef = new RowDefinition
        {
   
   
            Height = new GridLength(50, GridUnitType.Pixel)
        };
        myDynamicGrid.RowDefinitions.Add(rowDef);

        myDynamicGrid.ColumnDefinitions.Add(new ColumnDefinition {
   
    Width = new GridLength(750, GridUnitType.Pixel) });
        // 添加TextBlock
        TextBlock textBlock = new TextBlock
        {
   
   
            Text = "我的TextBlock",
            VerticalAlignment = VerticalAlignment.Top,
            HorizontalAlignment = HorizontalAlignment.Left,
            Margin = new Thickness(0,5,0,0)
        };
        Grid.SetRow(textBlock , i);
        Grid.SetColumn(textBlock , 0);
        m
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值