繁体   English   中英

如何动态更改 ListView WPF 中的列宽?

[英]How to dynamically change the column width in ListView WPF?

我正在写 WPF 应用程序。 我有一个包含 ListView 的简单 UserControl。 ListView 包含三列。 我想根据 UserControl 大小动态更改中间列的宽度,我需要用列表填充整个 UserControl。 这是我的 xaml 代码:

<UserControl 
             ...
             d:DesignHeight="540" 
             d:DesignWidth="750">
    <UserControl.Resources>
        <Converters:ItemTypeToImageConverter x:Key="ItemTypeToImageConverter"/>
        <Converters:ListWidthMultiConverter x:Key="ListWidthMultiConverter"/>
    </UserControl.Resources>
    <Grid>

        <ListView
            MinWidth="750"
            ItemContainerStyle="{StaticResource MainListItemStyle}"
            Background="{StaticResource LightBackgroundBrush}"
            BorderThickness="0"
            ItemsSource="{Binding ListItems}"
            SelectionMode="Single">
            <ListView.View>
                <GridView
                    AllowsColumnReorder="False">
                    <GridViewColumn Width="50">
                        <GridViewColumn.CellTemplate>
                            <DataTemplate DataType="{x:Type local:MainListItemVM}">
                                <Image
                                    HorizontalAlignment="Center"
                                    VerticalAlignment="Center"
                                    Width="30"
                                    Height="30"
                                    Source="{Binding Type, Converter={StaticResource ItemTypeToImageConverter}}"/>
                            </DataTemplate>
                    </GridViewColumn.CellTemplate>
                    </GridViewColumn>
                    <GridViewColumn DisplayMemberBinding="{Binding Name}">
                        <GridViewColumn.Width>
                            <MultiBinding 
                                Converter="{StaticResource ListWidthMultiConverter}">
                                <Binding 
                                    Path="ActualWidth"
                                    RelativeSource="{RelativeSource AncestorType=ListView}"/>
                                <Binding
                                    Path="View.Columns"
                                    RelativeSource="{RelativeSource AncestorType=ListView}"/>
                            </MultiBinding>
                        </GridViewColumn.Width>
                    </GridViewColumn>
                    <GridViewColumn Width="150" DisplayMemberBinding="{Binding Size}"/>
                </GridView>
            </ListView.View>

        </ListView>

    </Grid>
</UserControl>

这是我的转换器代码:

using System;
using System.Collections.Generic;
using System.Windows.Data;
using System.Globalization;
using System.Windows.Controls;


    public class ListWidthMultiConverter : IMultiValueConverter
    {

        public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture)
        {

            double userControlWidth = 750;
            double columnsWidth = 750;
            var columns = values[1] as IList<GridViewColumn>;

            if (double.TryParse(values[0].ToString(), out userControlWidth) && columns != null)
            {

                columnsWidth = columns[0].Width + columns[2].Width;

            }

            double returnValue = userControlWidth - columnsWidth;

            return returnValue > 0 ? returnValue : 0;

        }

        public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture) { throw new NotImplementedException(); }

    }



转换器正确计算宽度,但屏幕上没有任何反应。 尽管返回正确的值 (550),但视图中中间列的宽度绝对为 0。这不是唯一的问题; 当我尝试运行此代码时,对计算能力的要求非常高。 应用程序开始运行如此缓慢,以至于无法使用它。 转换器或 xaml 代码一定有问题,因为如果我剪掉它,添加用恒定值替换宽度,一切似乎都是正确的。 我究竟做错了什么?

好吧,我试图实现这一目标的方式非常复杂。 这是更好的解决方案(正常工作)。 在文件后面的代码中,您需要具有以下内容:


        public DirectoryContentList()
        {

            InitializeComponent();

            Application.Current.MainWindow.SizeChanged += ResizeNameColumn;

        }

        private void ResizeNameColumn(object sender, SizeChangedEventArgs args)
        {

            var newWidth = Application.Current.MainWindow.ActualWidth - (TypeColumn.Width + SizeColumn.Width + 290);
            NameColumn.Width = newWidth > 0 ?  newWidth :  0; //Cannot set negative value to the column width

        }

首先尝试在 xaml 文件中命名列,然后在后面的代码中手动更改宽度。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM