WPF ListView 自动调整列宽

ListView 控件:
 <ListView  ItemsSource="{Binding}" >
            <ListView.View>
                <GridView>
                    <GridViewColumn Header="账户"  >
                        <GridViewColumn.CellTemplate>
                            <DataTemplate>
                                <TextBlock Text="{Binding Path=FundAccountName}" HorizontalAlignment="Center" Width="auto" />
                            </DataTemplate>
                        </GridViewColumn.CellTemplate>
                    </GridViewColumn>
                    <GridViewColumn Header="数量" Width="*"> 
                        <GridViewColumn.CellTemplate>
                            <DataTemplate>
                                <TextBlock Text="{Binding Path=Position, StringFormat='0.##'}" HorizontalAlignment="Center" Width="auto" />
                            </DataTemplate>
                        </GridViewColumn.CellTemplate>
                    </GridViewColumn>
                </GridView>
            </ListView.View>
 </ListView>

在 GridViewColumn 中设置

Width="*"
或者是在 DataTemplate 中 设置

Width="auto"

并不能达到自动 , 列宽自动调整的效果, 列宽在控件第一次加载的时候已经确定,之后不会随着 某列数据长度的增加和减少 而改变列宽。


找了很多方法,感觉下面的这中方法比较简单和实用,在每次增加或者删除数据集合的时候,添加下列代码:

//调整列宽
            GridView gv = lvTrans.View as GridView;
            if (gv != null)
            {
                foreach (GridViewColumn gvc in gv.Columns)
                {
                    gvc.Width = gvc.ActualWidth;
                    gvc.Width = Double.NaN;
                }
            }
将 GridViewColumn 的 Width 属性 设置为 无效值,触发其自适应效果。


评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值