我有一个Panorama,它根据数据绑定获取动态数量的项目。在创建的PanoramaItem中,我有一个想要随时间修改的图像(随着时间的推移淡入/淡出不同的图像)。
我看到类似的问题:How to retrieve the name of a Panorama-Item at runtime?
但这对我不起作用,因为当我使用Panorama.Items[index]
时,我从未得到过PanoramaItem。我只获得了我使用的数据绑定的实例。
我来自Android世界,在那里我可以简单地使用类似findViewById()
的内容来获取特定视图。 WP8中有类似的东西吗?我知道FindName()
但我在Panorama上使用的只是返回null ...
所以我的问题是:如何在代码隐藏文件中获得名为GalleryPreview
的Image的引用?
我的页面xaml
<phone:PhoneApplicationPage
x:Class="App.View.AppDetailsPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}"
Foreground="{StaticResource PhoneForegroundBrush}"
SupportedOrientations="Portrait" Orientation="Portrait"
shell:SystemTray.IsVisible="False" >
<phone:PhoneApplicationPage.Resources>
<DataTemplate x:Key="PanoramaHeaderTemplate">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="72"/>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<Image Source="{Binding AppStoreIcon}"
Width="64" Height="64"
Grid.Column="0"
HorizontalAlignment="Left"/>
<TextBlock x:Name="ItemTitle"
Text="{Binding os}"
Grid.Column="1"/>
</Grid>
</DataTemplate>
<DataTemplate x:Key="PanormaItemTemplate">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="2*"/>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
<RowDefinition Height="Auto"/>
</Grid.RowDefinitions>
<TextBlock Text="{Binding storeName}" FontSize="24"
Grid.Row="0" Grid.Column="0" Grid.ColumnSpan="2"/>
<TextBlock Text="Rating" FontSize="24"
Grid.Row="1" Grid.Column="0"/>
<TextBlock Text="{Binding rating}" FontSize="24"
Grid.Row="1" Grid.Column="1"/>
<TextBlock Text="5 Stars: " FontSize="24"
Grid.Row="2" Grid.Column="0"/>
<TextBlock Text="{Binding starsFive}" FontSize="24"
Grid.Row="2" Grid.Column="1"/>
<TextBlock Text="4 Stars: " FontSize="24"
Grid.Row="3" Grid.Column="0"/>
<TextBlock Text="{Binding starsFour}" FontSize="24"
Grid.Row="3" Grid.Column="1"/>
<TextBlock Text="3 Stars: " FontSize="24"
Grid.Row="4" Grid.Column="0"/>
<TextBlock Text="{Binding starsThree}" FontSize="24"
Grid.Row="4" Grid.Column="1"/>
<TextBlock Text="2 Stars: " FontSize="24"
Grid.Row="5" Grid.Column="0"/>
<TextBlock Text="{Binding starsTwo}" FontSize="24"
Grid.Row="5" Grid.Column="1"/>
<TextBlock Text="1 Stars: " FontSize="24"
Grid.Row="6" Grid.Column="0"/>
<TextBlock Text="{Binding starsOne}" FontSize="24"
Grid.Row="6" Grid.Column="1"/>
<StackPanel Grid.ColumnSpan="2" Grid.Row="7"
ManipulationStarted="AppItemManipulationStarted"
ManipulationCompleted="AppItemManipulationCompleted">
<Image x:Name="GalleryPreview" Source="/Assets/images/blub.png"/>
</StackPanel>
</Grid>
</DataTemplate>
</phone:PhoneApplicationPage.Resources>
<!--LayoutRoot contains the root grid where all other page content is placed-->
<Grid x:Name="LayoutRoot">
<phone:Panorama x:Name="AppPanorama" Title="Title"
ItemsSource="{Binding}"
SelectionChanged="PanoramaSelectionChanged"
HeaderTemplate="{StaticResource PanoramaHeaderTemplate}"
ItemTemplate="{StaticResource PanormaItemTemplate}">
</phone:Panorama>
</Grid>
</phone:PhoneApplicationPage>
当我尝试使用FindName("GalleryPreview")
LogUtil.Log(AppPanorama.FindName("GalleryPreview") == null ? "null" : AppPanorama.FindName("GalleryPreview"));
LogUtil.Log(LayoutRoot.FindName("GalleryPreview") == null ? "null" : LayoutRoot.FindName("GalleryPreview"));
LogUtil.Log(AppPanorama.SelectedItem);
// output:
// null
// null
// App.Model.Store
答案 0 :(得分:1)
Control.GetTemplateChild可能就是你要找的东西。
模板具有自包含的名称范围。这是因为模板被重用,并且一旦控件的多个实例每个实例化其模板,模板中定义的任何名称都不能保持唯一。调用GetTemplateChild以便在实例化后返回对来自模板的对象的引用。您不能使用FindName从模板中查找项目,因为FindName在更一般的范围内起作用,并且一旦应用了ControlTemplate类本身和实例化模板之间就没有连接。
答案 1 :(得分:0)
试一试,看看是否有帮助:
Image newImg = new Image();
newImg = LayoutRoot.FindName("GalleryPreview") as Image;
答案 2 :(得分:0)
我想访问一个图像来更改计时器基础上显示的来源。
这是我的OnTick包含的图像引用:
ImageSourceConverter converter = new ImageSourceConverter();
PanoramaItem myPanoramaItem = (PanoramaItem)(AppPanorama.ItemContainerGenerator.ContainerFromItem(AppPanorama.Items[_selectedIndex]));
Image galleryItem = (Image)FindVisualChild<Image>("GalleryPreview", myPanoramaItem);
galleryItem.Source = (ImageSource)converter.ConvertFromString(gallery[_galleryIndex]);
“GalleryPreview”是我想要访问的图像的名称。由于我的布局中有多个图像,我需要扩展我在@wankr链接上找到的方法FindVisualChild
。
public static ChildItem FindVisualChild<ChildItem>(String name, DependencyObject obj) where ChildItem : DependencyObject
{
for (int i = 0; i < VisualTreeHelper.GetChildrenCount(obj); i++)
{
DependencyObject child = VisualTreeHelper.GetChild(obj, i);
FrameworkElement uiChild = (FrameworkElement)child;
if (child != null && child is ChildItem && uiChild.Name.Equals(name))
{
return (ChildItem)child;
}
else
{
ChildItem childOfChild = FindVisualChild<ChildItem>(name, child);
if (childOfChild != null)
{
return childOfChild;
}
}
}
return null;
}