0

我正在尝试获取当前单元格的整个宽度,以便我可以绘制一个宽度为该单元格一定百分比的矩形。正如此处所建议的,我无法多次绑定设置 Width 属性。所以我的下一个尝试是将网格与 UtilPct 传递给转换器,减去 150(第一列)并返回我的宽度。但是,网格没有宽度,它只是在 Snoop 中说 NaN,实际宽度为 0?

获得单元格实际计算宽度以便调整矩形宽度的最佳方法是什么?如果有人有任何其他方法,我很感激任何帮助!

XAML:

<ItemsControl x:Name="icBrokerCreditList" Grid.Row="1" Grid.Column="1" ItemsSource="{Binding Path=BrokerCreditList}" HorizontalAlignment="Stretch">
    <ItemsControl.ItemTemplate>
        <DataTemplate>
            <Grid HorizontalAlignment="Stretch" x:Name="brokerGrid">
                <Grid.RowDefinitions>
                    <RowDefinition Height="20"></RowDefinition>
                </Grid.RowDefinitions>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition Width="150"></ColumnDefinition>
                    <ColumnDefinition x:Name="utilCol" Width="*"></ColumnDefinition>
                </Grid.ColumnDefinitions>
                <TextBlock Grid.Row="0" Grid.Column="0" Background="White" Foreground="Black" FontSize="12" Text="{Binding Path=BrokerName}"></TextBlock>
                    <Rectangle Fill="Green" Height="20" Grid.Row="0" Grid.Column="1">
                        <Rectangle.Width>
                            <MultiBinding Converter="{StaticResource PercentageConverter}">
                                <Binding Path="ActualWidth" ElementName="utilCol" />
                                <Binding Path="UtilPct" />
                            </MultiBinding>
                        </Rectangle.Width>
                    </Rectangle>
                </TextBlock>
            </Grid>
        </DataTemplate>
    </ItemsControl.ItemTemplate>
</ItemsControl>
4

1 回答 1

1

您可以将 aScaleTransform用于RectangleRenderTransform 并将ScaleTransformX 属性绑定到您的百分比,而不是设置宽度。

注意:这将左对齐,Rectangle因为ScaleTransformCenterX 属性默认为 0。不幸的是,它使用绝对值而不是百分比,因此您不能使用具有未知宽度的 CenterX 来右对齐。您必须创建一个宽度设置为“自动”的第三列并将其Rectangle放入其中。要右对齐,请将 RenderTransformOrigin 设置为“1,0”。

注意:如果您的百分比实际上是一个百分比(即 [0-100]%、“55%”),则您必须将其通过转换器以将其除以 100 以获得适当的比例。

于 2013-05-17T17:34:28.820 回答