wpf的treeview显示item时候不能stretch的一个解决办法

      最近在帮朋友用wpf实现一个功能的时候遇到了treeviewitem总是默认最短的问题(对于我这次的功能是个问题),而且发现在网上很难找到解决办法(挺难的,网上找样式的时候还得要试一试,尤其是刚开始的时候,我真的看不懂wpf的样式代码……,真的跟摸着石头过河的赶脚,这个地方建议还是懵逼状态的朋友用一下blend,会有帮助,就是blend有时候安装的时候可能直接不能用,自己这边好像是把blend的一个开发包删了之后莫名其妙的能用了)。但是写代码有时候就是灵光一闪的事情,就在我踏破铁鞋google还有在其他的英文网站也找不到答案的时候,眼睛扫到代码里的一个单词:Auto。

      默认最短,不就是textblock的宽度是自适应的吗?就在这个时候我就觉得貌似我找到问题的症结了,于是开始看代码(一开始只是眼睛扫到了,我也不知道auto在哪……),无关项去掉之后如下:

 <Style x:Key="TreeViewItemStyle" TargetType="{x:Type TreeViewItem}">
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="{x:Type TreeViewItem}">
                        <Grid>
                            <Grid.ColumnDefinitions>
                                <ColumnDefinition MinWidth="19" Width="Auto"/>
                                <ColumnDefinition Width="Auto"/>
                                <ColumnDefinition Width="*"/>
                            </Grid.ColumnDefinitions>
                            <Grid.RowDefinitions>
                                <RowDefinition Height="Auto"/>
                                <RowDefinition/>
                            </Grid.RowDefinitions>
                            <ToggleButton x:Name="Expander" ClickMode="Press" IsChecked="{TemplateBinding IsExpanded}" Style="{StaticResource ExpandCollapseToggleStyle}" IsEnabled="False" Visibility="Collapsed" d:IsHidden="True" HorizontalContentAlignment="Stretch"/>
                            <Border x:Name="Bd" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" Grid.Column="1" Padding="{TemplateBinding Padding}" SnapsToDevicePixels="true">
                                <ContentPresenter x:Name="PART_Header" ContentSource="Header" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}"/>
                            </Border>
                            <ItemsPresenter x:Name="ItemsHost" Grid.ColumnSpan="2" Grid.Column="1" Grid.Row="1"/>
                        </Grid>
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>

      创建这个style的原因是为了让treeview默认全部展开,然而以上的代码段是自动生成的,而我没有做任何更改,该style传给treeview的ItemContainerStyle。可以看到默认这个grid被分为三列了,第一列是treeview的折叠按钮,第二列是我们的HierarchicalDataTemplate所展现的位置ContentPresenter,而它是Auto的……

    发现了这个之后我就把这个第二列去掉了,itemhosts的ColumSpan=2去掉之后,发现treeview是满屏的了,问题解决了。

    希望对不太了解wpf的朋友们有点帮助,睡觉……

转载于:https://www.cnblogs.com/Warriors/p/5986595.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值