2

我有一个带有 Viewbox 的 WPF 窗口。我希望此 Viewbox 的其中一个子元素在任何屏幕分辨率下都保持相同的大小。

我的 XAML:

<Viewbox Name="MyMainViewbox" Stretch="Fill">
<Grid Name="MyMainGrid">
    <Image Source="Images/bg.bmp" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Stretch="Fill"/>
    <Image Name="Thumb1" Source="Images/t1.png"  MouseUp="Right_Click"  Margin="0, 100, 50, 0" HorizontalAlignment="Right" VerticalAlignment="Stretch" Visibility="Visible"/>
    <Image Name="Thumb2" Source="Images/t2.png" MouseUp="Left_Click"  Margin="50, 100, 0, 0" HorizontalAlignment="Left"  VerticalAlignment="Stretch" Visibility="Visible"/>
    <Image Name="CurThumb" Width="640" Height="480" Stretch="UniformToFill"  Margin="0, 50, 0, 0" HorizontalAlignment="Center" VerticalAlignment="Center" Visibility="Hidden"/>
 </Grid>
</Viewbox>

Viewbox 中的前 2 个图像是预定义的,并在不同的屏幕分辨率下进行了精细缩放。我的问题是在运行时获取其源的第三张图像,并且在所有分辨率下都应该具有相同的精确尺寸。它将包含以 4x3 纵横比拍摄的照片,我希望它们保持不变。

但是在 16x9 屏幕分辨率下,它们会被拉伸。我试图在 XAML 中设置一个固定大小 - 它不起作用。我试图将 Stretch 设置为 None - 也不起作用。我试图在后面的代码中保留此图像的大小 - 无济于事。

我还能做些什么来使第三张图片无法缩放?出于几个原因,它应该留在 Viewbox 内。

4

1 回答 1

3

使用两个重叠的元素。

<Grid>
    <Viewbox>
        <Grid>
            ... scaled images
        </Grid>
    </Viewbox>
    <Grid>
        ... non scaled images
    <Grid>
<Grid>
于 2012-04-01T13:51:03.080 回答