在WPF中的ScrollViewer中显示大图像

时间:2016-01-25 20:59:34

标签: wpf image xaml scroll

我想在一个Window中显示一个大图像,如果它对于它所在的屏幕区域来说太大,那么Image将会有滚动条。

在图像下方,我想要一个按钮面板。为此,我将Image放在一个DockPanel中的ScrollViewer中,该DockPanel包含一个StackPanel,用于包含Bottom部分中的Buttons。我们的想法是单击“浏览”按钮来设置图像(从处理按钮单击后面的代码)

以下我放在一起的例子只是保持图像尺寸(2144 x 1424),我看不到下面的按钮面板。

<Window x:Class="WpfIssues.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:WpfIssues"
        mc:Ignorable="d"
        Title="MainWindow" Height="350" Width="525">
    <Grid>
        <DockPanel>
            <TextBlock Text="Test Image" FontSize="30" DockPanel.Dock="Top"></TextBlock>
            <StackPanel Orientation="Vertical">

                <DockPanel x:Name="PhotoPanel">

                    <StackPanel DockPanel.Dock="Bottom" Orientation="Horizontal" HorizontalAlignment="Right">
                        <Button Click="Button_Click">Browse...</Button>
                    </StackPanel>

                    <ScrollViewer 
                        HorizontalScrollBarVisibility="Auto" 
                        VerticalScrollBarVisibility="Auto">
                        <StackPanel>
                        <Image x:Name="PhotoImage" 
                                Stretch="None" 
                               Source="Resources/bear grills.png"
                                HorizontalAlignment="Center"
                                VerticalAlignment="Center" />
                        </StackPanel>
                    </ScrollViewer>


                </DockPanel>
            </StackPanel>
        </DockPanel>
    </Grid>
</Window>

我无法弄清楚原因。

1 个答案:

答案 0 :(得分:1)

尝试将按钮放在滚动查看器之前,如下所示:

<DockPanel>
    <TextBlock Text="Test Image" FontSize="30" DockPanel.Dock="Top" />
    <Button Content="Browse..." DockPanel.Dock="Bottom" />
    <ScrollViewer
                    HorizontalScrollBarVisibility="Auto"
                    VerticalScrollBarVisibility="Auto">
        <Image x:Name="PhotoImage"
                            Stretch="None"
                           Source="http://images6.fanpop.com/image/photos/33600000/Bear-Grylls-bear-grylls-33656894-3504-2336.jpg"
                            HorizontalAlignment="Center"
                            VerticalAlignment="Center" />
    </ScrollViewer>
</DockPanel>