1. 程式人生 > >WPF DataGrid橫向顯示

WPF DataGrid橫向顯示

mar resource rop part http enable head form item

前言

利用各種變換,將其水平改向至橫向顯示。

註意的是要固定好單元格的高寬,或者手動編寫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;
        
          
        }

        

       
    }

WPF DataGrid橫向顯示