弹出窗口中的全尺寸图像

时间:2012-03-12 13:03:12

标签: image windows-phone-7 listbox popup

我正在使用带有自定义DataTemplate的ListBox,在这个DataTemplate中我有两个缩略图,当用户点击其中一个图像时,我需要显示一个带有全尺寸图像的弹出窗口(类似于JavaScript中的灯箱)。我尝试在DataTemplate中使用Popup控件,但是弹出窗口定位到ListBox上的当前元素,而不是屏幕中心,我无法将其设置为模态。我也尝试使用Coding4Fun工具包,但我找不到任何文档或在没有任何帮助的情况下完成。

以下是列表框的代码:

<ListBox MaxHeight="600" ItemsSource="{Binding Items}" x:Name="LooksList" u:ScrollViewerMonitor.AtEndCommand="{Binding FetchMoreDataCommand}" d:LayoutOverrides="GridBox" BorderThickness="0" Margin="0,0,0,62">
    <ListBox.ItemTemplate>
        <DataTemplate>
            <views:LookListItem />
        </DataTemplate>
    </ListBox.ItemTemplate>
</ListBox>

和视图:LookListItem:

<Grid x:Name="LayoutRoot">
    <StackPanel x:Name="MainPanel" Margin="0,53,0,0" Orientation="Horizontal">
        <StackPanel x:Name="PhotosPanel" Margin="20,11,0,0" Width="198" Height="126" HorizontalAlignment="Left" VerticalAlignment="Top" Orientation="Horizontal">
            <Border BorderThickness="3" BorderBrush="White" Margin="0" HorizontalAlignment="Left" Width="93" Height="126">
                <Image Source="{Binding Photo1.Thumb}" VerticalAlignment="Center" Tap="Image_Tap" />
            </Border>
            <Border BorderThickness="3" BorderBrush="White" Margin="12,0,0,0" HorizontalAlignment="Right" Width="93" Height="126">
                <Image Source="{Binding Photo2.Thumb}" VerticalAlignment="Center" />
            </Border>
        </StackPanel>
    </StackPanel>
</Grid>

Photo1和Photo2应该是可点击的,点击后它应该是一个弹出窗口。

提前致谢!

1 个答案:

答案 0 :(得分:0)

有几种方法可以做到这一点。我将展示如何使用一些代码完成此操作。

在你的xaml中:

<Grid>
    <ListBox ItemsSource="{Binding MyItems}" ItemTemplate="{Binding MyTemplate}"
             SelectionChanged="ListBox_SelectionChanged"/>
    <Popup x:Name="Popup">
        <Grid>
            <ToggleButton Content="X" 
                          IsChecked="{Binding IsOpen, ElementName=Popup, Mode=TwoWay}"
                          HorizontalAlignment="Right" VerticalAlignment="Top"/>
            <Image x:Name="PopupImage"/>
        </Grid>
    </Popup>
</Grid>

在你的代码背后:

private void ListBox_SelectionChanged(object sender, SelectionChangedEventArgs args)
{
    ListBox listBox = (ListBox)sender;
    MyImageObject obj = (MyImageObject)listBox.SelectedItem;
    ImagePopup.Source = MyImageObjct.LargeImageSource;
    Popup.IsOpen = true;
    // Unselect item so user can "reselect" it -- If you need item later, save it somewhere
    listBox.SelectedItem = null;
}

// Handle the back key button to close the popup
protected override void OnBackKeyPress(CancelEventArgs e)
{
    if(Popup.IsOpen)
    {
        Popup.IsOpen = false;
        e.Cancel = true;
    }
}

根据最新信息进行更新 如果您不需要单独的UserControl中的视图(没有逻辑,只有控件的位置),您仍然可以使用该示例,但不是监听SelectionChanged事件,而是收听每个图像的Tap事件。

<ListBox MaxHeight="600" ItemsSource="{Binding Items}" x:Name="LooksList"
         BorderThickness="0" Margin="0,0,0,62">
<ListBox.ItemTemplate>
    <DataTemplate>
        <StackPanel x:Name="MainPanel" Margin="0,53,0,0" Orientation="Horizontal">
            <StackPanel x:Name="PhotosPanel" Margin="20,11,0,0" Width="198" Height="126" HorizontalAlignment="Left" VerticalAlignment="Top" Orientation="Horizontal">
                <Border BorderThickness="3" BorderBrush="White" Margin="0" HorizontalAlignment="Left" Width="93" Height="126">
                    <Image Source="{Binding Photo1.Thumb}" VerticalAlignment="Center" Tap="Image1_Tap" />
                </Border>
                <Border BorderThickness="3" BorderBrush="White" Margin="12,0,0,0" HorizontalAlignment="Right" Width="93" Height="126">
                    <Image Source="{Binding Photo2.Thumb}" VerticalAlignment="Center"
                           Tap="Image2_Tap" />
                </Border>
            </StackPanel>
        </StackPanel>
    </DataTemplate>
</ListBox.ItemTemplate>

Tap事件的事件看起来像

    private void Image1_Tap(object sender, GestureEventArgs gestureEventArgs)
    {
        MyImageObject obj = ((FrameworkElement)sender).DataContext as MyImageObject;
        // This is the event for Image1 Thumb, so show the Image1 Large
        ShowPopup(obj.Photo1.Large);
    }

如果确实需要单独的UserControl 您可以像我的Custom MessageBox Post一样创建“ImageOverlay”视图。在您的LookListItem视图中,订阅两个拇指的点击事件

<Grid x:Name="LayoutRoot">
<StackPanel x:Name="MainPanel" Margin="0,53,0,0" Orientation="Horizontal">
    <StackPanel x:Name="PhotosPanel" Margin="20,11,0,0" Width="198" Height="126" HorizontalAlignment="Left" VerticalAlignment="Top" Orientation="Horizontal">
        <Border BorderThickness="3" BorderBrush="White" Margin="0" HorizontalAlignment="Left" Width="93" Height="126">
            <Image Source="{Binding Photo1.Thumb}" VerticalAlignment="Center" Tap="Thumb1_Tap" />
        </Border>
        <Border BorderThickness="3" BorderBrush="White" Margin="12,0,0,0" HorizontalAlignment="Right" Width="93" Height="126">
            <Image Source="{Binding Photo2.Thumb}" VerticalAlignment="Center" Tap="Thumb2_Tap" />
        </Border>
    </StackPanel>
</StackPanel>

在点击事件中显示ImageOverlay控件

    private void Thumb1_Tap(object sender, GestureEventArgs gestureEventArgs)
    {
        ShowOverlay(Photo1.Large);
    }

    private void Thumb2_Tap(object sender, GestureEventArgs gestureEventArgs)
    {
        ShowOverlay(Photo2.Large);
    }

    private void ShowOverlay(ImageSource source)
    {
        ImageOverlay overlay = new ImageOverlay();
        overlay.ImageSource = source;
        overlay.Show();
    }