WPF DataGrid横向显示

前言

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

注意的是要固定好单元格的高宽,或者手动编写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;
        
          
        }

        

       
    }
复制代码

 

posted @   ARM830  阅读(3452)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示