利用HeaderRender使DataGrid支持居中

本文探讨了在Flex3的AdvanceDataGrid中实现表头居中的方法。作者尝试了多种方案,并最终通过监听datachange事件和覆盖setdata方法成功实现了需求。
最近研究Flex3的AdvanceDataGrid。发现了一些和DataGrid同样的问题。
datagrid中的header默认是左对齐的,也不能够使用headerstyle让文字改变对齐方式。AdvanceDataGrid也一样。
最近要做的东西需要使header居中,所以我能想到的办法就是headerrender。
自己构造了一个组件,用一个vbox里面加了一个label,然后把vbox设置成居中,把DataGridColumn的HeaderRender设成了
new ClassFactory( xx );xx就是这个东东的类名。但是发现即使设置了headerText也没用。换用Label发现是可以的。
于是开始debug,Flex的代码中确实有很多地方是写死的,相当的没有灵活性。试了好多方法,最后决定先用Label,然后在get text上设断点。结果在AdvancedDataGridBase中找到了createHeaders方法,这是AdvanceDataGrid的父类。断点停在了
                item.data = c;
                item.styleName = c;
item就是render.newInstance()的返回值。data是DataGridColumn类型的。这下知道了,有几种办法,既可以监听datachange事件,又可以覆盖set data方法。
 
在WPF中,让DataGrid内容居中可从单元格内容居中和表头内容居中两方面进行设置。 ### 表头内容居中 可通过设置`DataGridColumnHeader`的`HorizontalContentAlignment`属性来实现表头内容居中。有以下两种方式: #### 方式一:定义样式资源 ```xml <Style x:Key="MyDataGridColumnHeader" TargetType="DataGridColumnHeader" BasedOn="{StaticResource MaterialDesignDataGridColumnHeader}"> <Setter Property="HorizontalContentAlignment" Value="Center" /> </Style> ``` 然后在`DataGrid`中引用该样式: ```xml <DataGrid ColumnHeaderStyle="{StaticResource MyDataGridColumnHeader}"> <!-- 列定义 --> </DataGrid> ``` #### 方式二:直接在`DataGrid`中设置样式 ```xml <DataGrid> <DataGrid.ColumnHeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="HorizontalContentAlignment" Value="Center"/> <!-- 可添加其他属性设置,如背景色、前景色等 --> <Setter Property="Background" Value="#001f55"/> <Setter Property="Foreground" Value="#17acae"/> <Setter Property="BorderThickness" Value="1" /> <Setter Property="BorderBrush" Value="#17acae" /> </Style> </DataGrid.ColumnHeaderStyle> <!-- 列定义 --> </DataGrid> ``` ### 单元格内容居中 #### 方式一:使用`CellStyle`属性 先定义一个样式资源: ```xml <Window.Resources> <Style x:Key="DataGridCellStyle" TargetType="DataGridCell"> <Setter Property="HorizontalContentAlignment" Value="Center"/> <Setter Property="VerticalContentAlignment" Value="Center"/> </Style> </Window.Resources> ``` 然后在`DataGridTextColumn`中引用该样式: ```xml <DataGrid x:Name="dataGrid" ItemsSource="{Binding Loginlogs}" AutoGenerateColumns="False" CanUserAddRows="False"> <DataGrid.Columns> <DataGridTextColumn Header="登录账号" Binding="{Binding Manager_id}" CellStyle="{StaticResource DataGridCellStyle}"/> <DataGridTextColumn Header="登录名" Binding="{Binding Manager_name}" CellStyle="{StaticResource DataGridCellStyle}"/> <DataGridTextColumn Header="登录时间" Binding="{Binding login_time}" CellStyle="{StaticResource DataGridCellStyle}"/> </DataGrid.Columns> </DataGrid> ``` #### 方式二:设置`ElementStyle` 先定义一个针对`TextBlock`的样式资源: ```xml <Window.Resources> <ResourceDictionary> <Style x:Key="dgCell" TargetType="TextBlock"> <Setter Property="TextAlignment" Value="Center"/> </Style> </ResourceDictionary> </Window.Resources> ``` 然后在`DataGridTextColumn`中使用该样式: ```xml <DataGrid Name="dgBuild" ItemsSource="{Binding}" AutoGenerateColumns="False"> <DataGrid.Columns> <DataGridTextColumn Width="*" Binding="{Binding ItemName}" ElementStyle="{StaticResource dgCell}"/> <DataGridTextColumn Width="*" Binding="{Binding Data}" ElementStyle="{StaticResource dgCell}"/> </DataGrid.Columns> </DataGrid> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值