StackPanel扩展父网格的外部大小

时间:2012-09-04 16:03:07

标签: wpf

我是WPF的新手,如果我遗漏了一些显而易见的东西,请道歉。我有这个模板绑定到obs中的项目。采集。我试图得到它,以便第二列,“测试测试...”部分具有可变宽度,填充父网格中的所有可用空间。

我发现的是,我的代码会自动显示该“测试测试...”文本框的所有文本,而不是仅仅绑定到网格中的可用空间,而是创建滚动条,你看下面。

enter image description here

相反,我希望切断“测试测试”,以便其他所有内容都适合,以便不显示滚动条(当用户调整屏幕大小时,那么“测试测试...”文本框将自动调整大小适应新的空间)。有没有办法做到这一点?

该模板的代码如下:

            <DataTemplate x:Key="MainTemplate">
            <Grid Margin="4" ClipToBounds="True">
                <Grid.Resources>
                    <local:BooleanToHiddenVisibility x:Key="boolToVis"/>
                </Grid.Resources>
                <StackPanel Orientation="Vertical" ClipToBounds="True">
                    <Grid Width="Auto" >
                        <Grid.ColumnDefinitions>
                            <ColumnDefinition Width="25"/>
                            <ColumnDefinition Width="Auto" />
                            <ColumnDefinition Width="60" />
                            <ColumnDefinition Width="40" />
                            <ColumnDefinition Width="60" />
                            <ColumnDefinition Width="40" />
                            <ColumnDefinition Width="60" />
                            <ColumnDefinition Width="40" />
                            <ColumnDefinition Width="40" />
                        </Grid.ColumnDefinitions>
                        <CheckBox Grid.Column="0" Name="checkViewTextBox"/>
                        <TextBlock Grid.Column="1" Text="{Binding OriginalQuote}" FontWeight="Bold" TextTrimming="WordEllipsis" FontStyle="Italic" ClipToBounds="True"/>

                        <TextBlock Margin="10,0,0,0" Grid.Column="2"  Text="plane :" FontWeight="SemiBold" Width="60"/>
                        <TextBlock Margin="5,0,0,0" Grid.Column="3" Text="{Binding Mid}" Width="40"/>

                        <TextBlock Margin="10,0,0,0" Grid.Column="4"  Text="data2 :" FontWeight="SemiBold" Width="60"/>
                        <TextBlock Margin="5,0,0,0" Grid.Column="5" Text="{Binding MidTwo}" Width="40"/>

                        <TextBlock Margin="10,0,0,0" Grid.Column="6"  Text="data3:" FontWeight="SemiBold" Width="60"/>
                        <TextBlock Margin="5,0,0,0" Grid.Column="7" Text="{Binding MidThree}" Width="40"/>

                        <Button Margin="10,0,0,0" Content="History" Grid.Column="8" Click="History_Click" Width="40"/>
                    </Grid>

                    <StackPanel Orientation="Horizontal" Visibility="{Binding Path=IsChecked, ElementName=checkViewTextBox, Converter={StaticResource boolToVis}}">
                        <StackPanel.Resources>
                            <Style BasedOn="{StaticResource tbstyle}" TargetType="{x:Type TextBlock}" />
                        </StackPanel.Resources>
<!--Other stuff thats working ok-->

                </StackPanel>
            </Grid>
        </DataTemplate>

非常感谢任何帮助!

P.S。我一直在添加随机的礼仪,希望一个可以工作,所以如果看起来我有随机的东西,那可能是为什么......

1 个答案:

答案 0 :(得分:3)

嗯,不确定它会对你有所帮助,但有些关于WPF布局的话。

它有两个步骤:衡量和安排。

在第一阶段,控件尝试计算其所需的状态。 StackPanel向孩子们询问他们想要的尺码。它不限制它们的大小。 (绑定到OriginalQoute的TextBlock没有明确设置宽度!)

在第二阶段,安排控制。 允许堆栈面板占据列的整个左侧空间,但它将其子项排列为其大小无限制,因此TextBlock完全显示文本。

问题是如何限制TextBlock的大小?

尝试绑定

<TextBlock Width="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType=StackPanel}, Path=ActualWidth}"/>