私はepgsのリストをロードする必要があるWindows Phone 8アプリで書いています。そのために、リストボックスとデータテンプレートを使用しています。
<DataTemplate x:Key="FooDataTemplate">
<Button Margin="0,10,0,0" Style="{Binding Source={StaticResource ButtonNoMarginStyle}}" BorderThickness="0" Width="375" Height="105" Command="{Binding ElementName=pageRoot,Path=ViewModel.NavigateToDetailsCommand}" CommandParameter="{Binding Id}">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="180"/>
<ColumnDefinition Width="195"/>
</Grid.ColumnDefinitions>
<Grid Grid.Column="0">
<Grid.RowDefinitions>
<RowDefinition Height="*"/>
<RowDefinition Height="25"/>
</Grid.RowDefinitions>
<controls:ImageControl ImageUri="{Binding Image}" Grid.RowSpan="2" Grid.Column="0" />
<Image Grid.RowSpan="2" Source="{StaticResource SecondCaptionImage}" Grid.Column="0" VerticalAlignment="Top" HorizontalAlignment="Right" Stretch="None"/>
<Grid Grid.Row="1" Visibility="{Binding IsCurrentEpg, Converter={StaticResource BooleanToVisibilityConverter}}">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="10"/>
<ColumnDefinition Width="*"/>
<ColumnDefinition Width="auto"/>
<ColumnDefinition Width="10"/>
</Grid.ColumnDefinitions>
<Rectangle Fill="#cc3e567b" Grid.ColumnSpan="4"/>
<TextBlock Text="DIRECT" FontSize="12" Grid.Column="1" HorizontalAlignment="Left" VerticalAlignment="Center"/>
<TextBlock Text="{Binding Duration}" FontSize="12" Grid.Column="2" VerticalAlignment="Center"/>
</Grid>
</Grid>
<Grid Grid.Column="1" VerticalAlignment="Top" Margin="10,-8,0,0">
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<!--Title-->
<RowDefinition Height="auto"/>
<!--SubTitle-->
<RowDefinition Height="auto"/>
<!--Hours-->
<RowDefinition Height="auto"/>
<!--Progress bar if needed-->
</Grid.RowDefinitions>
<TextBlock TextTrimming="WordEllipsis" Text="{Binding Title, Converter={StaticResource CaseStringConverter}, ConverterParameter=Upper}"/>
<TextBlock Grid.Row="1" TextTrimming="WordEllipsis" Text="{Binding Subtitle, Converter={StaticResource CaseStringConverter}, ConverterParameter=Upper}"/>
<TextBlock Grid.Row="2" Text="{Binding DurationTitle}"/>
<Grid Margin="-4,0,0,0" Grid.Row="3" Visibility="{Binding IsCurrentEpg, Converter={StaticResource BooleanToVisibilityConverter}}" >
<controls:EpgProgressBar Visibility="{Binding IsCurrentEpg, Converter={StaticResource BooleanToVisibilityConverter}}" Loaded="SecondProgressBarLoaded" IsEnabled="{Binding IsCurrentEpg}" CurrentEpg="{Binding}" Width="375" HorizontalAlignment="Left" />
</Grid>
</Grid>
</Grid>
</Button>
</DataTemplate>
ご覧のとおり、1 つの EpgProgressBar を使用し、それが現在の Epg である場合にのみ表示します。ビューは正しく設定されており、現在の EPG の進行状況バーのみが表示されます。しかし、私の出力では、各ボタンに 1 つのプログレス バーがあることがわかります。
このコントロールが折りたたまれているか非表示になっている場合、カスタム コントロール (私の場合はプログレス バー) を読み込まない方法はありますか?
よろしく。