WPF下使用DataGrid,表头靠左,动态添加行和列

<Window x:Class="WpfApp1.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:local="clr-namespace:WpfApp1"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">

    <Window.Resources>
        <Style TargetType="DataGridRow" >
            <Setter Property="Height" Value="100" />
        </Style>
        <Style TargetType="DataGridCell">
            <Setter Property="IsEnabled" Value="True"/>
            <Setter Property="LayoutTransform">
                <Setter.Value>
                    <TransformGroup>
                        <ScaleTransform ScaleX="1" ScaleY="-1"/>
                        <RotateTransform Angle="90"/>
                    </TransformGroup>
                </Setter.Value>
            </Setter>
        </Style>
        <Style TargetType="DataGridColumnHeader">
            <Setter Property="IsEnabled" Value="False"/>
            <Setter Property="LayoutTransform">
                <Setter.Value>
                    <TransformGroup>
                        <RotateTransform Angle="-90"/>
                        <ScaleTransform ScaleX="1" ScaleY="-1"/>
                    </TransformGroup>
                </Setter.Value>
            </Setter>
        </Style>
    </Window.Resources>
    <Grid  >
        <ScrollViewer Height="550" Width="550">
            <DataGrid ScrollViewer.VerticalScrollBarVisibility="Auto" SelectionUnit="FullRow" SelectionMode="Single" ScrollViewer.HorizontalScrollBarVisibility="Auto"  HeadersVisibility="Column" x:Name="DG"   >
                <DataGrid.LayoutTransform>
                    <TransformGroup>
                        <RotateTransform Angle="-90"/>
                        <ScaleTransform ScaleX="1" ScaleY="-1"/>
                    </TransformGroup>
                </DataGrid.LayoutTransform>
            </DataGrid>
        </ScrollViewer>
    </Grid>
</Window>

后台代码
 


namespace WpfApp1
{

    public class ColumeModel
    {
        public string ColumeName { get; set; }

        public DataType ColueType { set; get; }

    }
    public enum DataType
    {
        Label,
        TextBlocak, 
        CheckBox,
        Combox
    }
  

    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindow : Window
    {

        /// <summary>
        /// 绑定的数据
        /// </summary>
        ObservableCollection<ExpandoObject> DataTableViewModel = new ObservableCollection<ExpandoObject>();

        /// <summary>
        /// 源数据列集合
        /// </summary>
        private List<ColumeModel> List = new List<ColumeModel>();

        public MainWindow()
        {
            InitializeComponent();
            //模拟列头源数据
            for (var i = 0; i < 10; i++)
            {
                var model = new ColumeModel
                {
                    ColueType = DataType.Label,
                    ColumeName = "colume" + (i + 1)
                };
                if (i == 0) 
                {
                    model.ColueType = DataType.Combox;
                }
                List.Add(model); 
            }
            //生成列
            List.ForEach(item => {
                if (item.ColueType == DataType.Combox)
                {
                    DataGridTemplateColumn col = new DataGridTemplateColumn();
                    var comboBox =new  FrameworkElementFactory(typeof(ComboBox));
                    comboBox.SetValue(ComboBox.ItemsSourceProperty, List); 
                    comboBox.SetValue(ComboBox.SelectedIndexProperty,1); 
                    var comboBox = new FrameworkElementFactory(typeof(ComboBox));
                    comboBox.SetValue(ComboBox.ItemsSourceProperty, List);
                    Binding binding = new Binding();
                    binding.Mode = BindingMode.TwoWay;
                    binding.UpdateSourceTrigger = UpdateSourceTrigger.PropertyChanged;
                    binding.Path =new PropertyPath(item.ColumeName);
                    comboBox.SetBinding(ComboBox.TextProperty, binding);
                    stackPanelFactory.AppendChild(comboBox);
                    var dataTemplate = new DataTemplate
                    {
                        VisualTree = stackPanelFactory
                    };
                    var templateColumn = new DataGridTemplateColumn
                    {
                        Header = item.ColumeName,
                        CellTemplate = dataTemplate
                    };
                    DG.Columns.Add(templateColumn);
                }
                else
                { 
                   DG.Columns.Add(new DataGridTextColumn() { Header = item.ColumeName, Binding = new Binding(item.ColumeName),IsReadOnly=true });
                }
                
            });
            //添加20个数据
            for (int i = 0; i < 20; i++)
            {
                var itm = new ExpandoObject();
                
                List.ForEach(item => {
                    itm.TryAdd(item.ColumeName,i+1);
                });
                DataTableViewModel.Add(itm);
            }
            DG.ItemsSource = DataTableViewModel;
        } 
    }
}

实现效果

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

这个月太忙没时间看C++

你的鼓励将是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值