我正在尝试使用以下模板创建一个包含项目的列表框
<ListBox x:Name="moviesactedin" Style="{StaticResource ListBoxStyle2}">
<ListBox.ItemTemplate>
<DataTemplate>
<Border BorderThickness="0,0,0,1" BorderBrush="Black" Margin="0,0,0,5">
<StackPanel Orientation="Horizontal" Margin="0,0,0,5" HorizontalAlignment="Stretch">
<Image Source="{Binding Image}" Stretch="None" Margin="0,0,5,5" />
<StackPanel Orientation="Vertical" Margin="10,0,0,0" VerticalAlignment="Top">
<TextBlock Text="{Binding Title}" Foreground="Black" FontWeight="Bold"/>
<TextBlock Text="{Binding Director}" Foreground="Black"/>
<TextBlock Text="{Binding ReleaseDate}" Foreground="Black"/>
</StackPanel>
<Image Source="/Images/icon_arrow.png" HorizontalAlignment="Right" VerticalAlignment="Center"/>
</StackPanel>
</Border>
</DataTemplate>
</ListBox.ItemTemplate>
和列表框样式
<Style x:Key="ListBoxStyle2" TargetType="ListBox">
<Setter Property="Background" Value="Transparent"/>
<Setter Property="Foreground" Value="{StaticResource PhoneForegroundBrush}"/>
<Setter Property="ScrollViewer.HorizontalScrollBarVisibility" Value="Disabled"/>
<Setter Property="ScrollViewer.VerticalScrollBarVisibility" Value="Auto"/>
<Setter Property="BorderThickness" Value="0"/>
<Setter Property="BorderBrush" Value="Transparent"/>
<Setter Property="Padding" Value="0"/>
<Setter Property="HorizontalAlignment" Value="Stretch" />
<Setter Property="HorizontalContentAlignment" Value="Stretch"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="ListBox">
<ItemsPresenter HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"/>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
第一个图像将在左侧,带有三个文本块的 stackPanel 将在中间,第二个图像将在右侧(最后)。
问题是列表框项目没有填满屏幕的整个宽度,因此我将最后一个图像放在屏幕宽度的末尾。
有什么帮助吗?