<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;
}
}
}
实现效果