Show image in Full screen

前端 未结 2 395
暗喜
暗喜 2021-01-16 14:58

I am working on Windows Phone 8 app and have a Image view like this in XAML:



        
相关标签:
2条回答
  • 2021-01-16 15:33

    Bottom bar is ApplicationBar and top bar is SystemTray. If you create a new page without the ApplicationBar and with SystemTray.IsVisible to false, you have a fullscreen page. Now, instead of having a Grid at the root, place just one Image and you can use that page as a fullscreen viewer.

    <phone:PhoneApplicationPage
        x:Class="SimpleApp.FullScreenPage"
        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"
        FontFamily="{StaticResource PhoneFontFamilyNormal}"
        FontSize="{StaticResource PhoneFontSizeNormal}"
        Foreground="{StaticResource PhoneForegroundBrush}"
        SupportedOrientations="Portrait" Orientation="Portrait"
        mc:Ignorable="d"
        shell:SystemTray.IsVisible="False">
    
        <Image Name="myImage" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"
             Stretch="Uniform"/>
    
    </phone:PhoneApplicationPage>
    

    In MainPage where you tap image:

    private void myImg_Tap(object sender, System.Windows.Input.GestureEventArgs e)
    {
       string context = ((sender as Image).Source as BitmapImage).UriSource.ToString();
       NavigationService.Navigate(new Uri(String.Concat("/Page1.xaml?context=", context), UriKind.RelativeOrAbsolute));
    }
    

    In Fullscreenpage:

    protected override void OnNavigatedTo(NavigationEventArgs e)
    {
       string context = this.NavigationContext.QueryString["context"];
       myImage.Source = new BitmapImage(new Uri(context, UriKind.RelativeOrAbsolute));
       base.OnNavigatedTo(e);
    }
    
    0 讨论(0)
  • 2021-01-16 15:49

    An alternative approach, without passing the image details between pages, is to display a Popup:

    private void HandleTapImage(object sender, GestureEventArgs e)
    {
        var myPopup = new Popup
        {
            Child = new Image
            {
                Source = ((Image) sender).Source,
                Stretch = Stretch.UniformToFill,
                Height = Application.Current.Host.Content.ActualHeight,
                Width = Application.Current.Host.Content.ActualWidth
            }
        };
        myPopup.IsOpen = true; 
    }
    

    (Select Strech value best suited for your needs). With this approach however you have to manually hide ApplicationBar and SystemTray, if present, in the HandleTapImage method. You also have to take care of hiding the Popup and showing the bars again.

    0 讨论(0)
提交回复
热议问题