2

我想访问 C# 代码中的“图像”元素。我知道我不能直接访问它,因为它在数据模板中。我已经尝试过视觉树,但仍然无法在代码中获取“图像”控制元素。

<FlipView
            x:Name="flipView"
            AutomationProperties.AutomationId="ItemsFlipView"
            AutomationProperties.Name="Item Details"
            TabIndex="1"
            Grid.RowSpan="2"
            ItemsSource="{Binding Source={StaticResource itemsViewSource}}" SelectionChanged="flipView_SelectionChanged">

            <FlipView.ItemContainerStyle>
                <Style TargetType="FlipViewItem">
                    <Setter Property="Margin" Value="0,137,0,0"/>
                </Style>
            </FlipView.ItemContainerStyle>

            <FlipView.ItemTemplate>
                <DataTemplate>

                    <!--
                        UserControl chosen as the templated item because it supports visual state management
                        Loaded/unloaded events explicitly subscribe to view state updates from the page
                    -->
                    <UserControl Loaded="StartLayoutUpdates" Unloaded="StopLayoutUpdates">
                        <ScrollViewer x:Name="scrollViewer" Style="{StaticResource HorizontalScrollViewerStyle}" Grid.Row="1">

                            <!-- Content is allowed to flow across as many columns as needed -->
                            <common:RichTextColumns x:Name="richTextColumns" Margin="117,0,117,47">
                                <RichTextBlock x:Name="richTextBlock" Width="560" Style="{StaticResource ItemRichTextStyle}" IsTextSelectionEnabled="False">
                                    <Paragraph>
                                        <Run FontSize="26.667" FontWeight="Light" Text="{Binding Title}"/>
                                        <LineBreak/>
                                        <LineBreak/>
                                        <Run FontWeight="Normal" Text="{Binding Subtitle}"/>
                                    </Paragraph>
                                    <Paragraph LineStackingStrategy="MaxHeight">
                                        <InlineUIContainer>
                                            <Image x:Name="image" MaxHeight="480" Margin="0,20,0,10" Stretch="Uniform" Source="{Binding Image}" AutomationProperties.Name="{Binding Title}"/>
                                        </InlineUIContainer>
                                    </Paragraph>                                  
                                </RichTextBlock>
                            </common:RichTextColumns>
                        </ScrollViewer>
                    </UserControl>
                </DataTemplate>
            </FlipView.ItemTemplate>
</FlipView>
4

2 回答 2

3

我已经尝试过,并且可以按照您的描述访问 FlipView DataTemplate 内部的控件。尝试以下方法,让我知道这是否有帮助。

public static IEnumerable<T> RecurseChildren<T>(DependencyObject root) where T : UIElement
{
    if (root is T)
    {
        yield return root as T;
    }

    if (root != null)
    {
        var count = VisualTreeHelper.GetChildrenCount(root);


        for (var idx = 0; idx < count; idx++)
        {
            foreach (var child in RecurseChildren<T>(VisualTreeHelper.GetChild(root, idx)))
            {
                yield return child;
            }
        }
    }
}

访问图像控制:

var imageControl = RecurseChildren<Image>(rootVisual).FirstOrDefault();

这里 rootVisual 是我页面中的 Grid 实例。

于 2012-10-01T10:59:29.917 回答
2

在这里回答https://stackoverflow.com/a/16446670/265706

简短的回答是:您遇到的问题是 DataTemplate 正在重复并且内容是由他的 FlipView 生成的。名称没有公开,因为它会与生成的前一个兄弟姐妹(或将要生成的下一个兄弟姐妹)冲突。

因此,要在 DataTemplate 中获取命名元素,您必须首先获取生成的项目,然后在生成的项目中搜索所需的元素。请记住,XAML 中的逻辑树是您按名称访问事物的方式。生成的项目不在逻辑树中。相反,它们位于可视树中(所有控件都位于可视树中)。这意味着您必须在可视树中搜索要引用的控件。VisualTreeHelper 允许您执行此操作。

于 2013-05-08T18:32:43.807 回答