前言
利用各種變換,將其水平改向至橫向顯示。
注意的是要固定好單元格的高寬,或者手動編寫style
否者在滾動的時候,會有高寬比例不一樣的時候
再其次,要注意datagrid的容器或者datagrid中的集合的數量,數量過多,請適當做出優化,容器則是放入scrollview中即可。
效果圖

基本XAML代碼
<Window.Resources>
<Style TargetType="DataGridRow" >
<Setter Property="Height" Value="40" />
</Style>
<Style TargetType="DataGridCell">
<Setter Property="IsEnabled" Value="False"/>
<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="65" Width="125">
<DataGrid ScrollViewer.VerticalScrollBarVisibility="Auto" 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>
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=0;i<300;i++) { Test.Add(new TestClass() { Age = i, ID = 1, Name = NAME + i.ToString() }); } DG.ItemsSource = Test; } }
