前言

利用各种变换,将其水平改向至横向显示。

注意的是要固定好单元格的高宽,或者手动编写style

否者在滚动的时候,会有高宽比例不一样的时候

再其次,要注意datagrid的容器或者datagrid中的集合的数量,数量过多,请适当做出优化,容器则是放入scrollview中即可。

效果图

WPF DataGrid横向显示-LMLPHP

基本XAML代码

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

cs代码

 public class TestClass
{
public string Name { get; set; } public int ID { get; set; } public int Age { get; set; }
} /// <summary>
/// MainWindow.xaml 的交互逻辑
/// </summary>
public partial class MainWindow : Window
{
List<TestClass> Test;
string NAME="N";
public MainWindow()
{
InitializeComponent();
Test = new List<TestClass>(); for(var i=;i<;i++)
{
Test.Add(new TestClass() { Age = i, ID = , Name = NAME + i.ToString() });
}
DG.ItemsSource = Test; } }
05-11 22:28