重新模板化这样的窗口并不是我做这类事情的真正方式。
我会使用更类似于此示例中的方法的方法:
https://gallery.technet.microsoft.com/ThWPFPolishing-Chrome-f41be7fe
完成的花式窗口是
data:image/s3,"s3://crabby-images/abc0e/abc0e299c1291c2a3cd6bbc3f6d7737229392f53" alt="在此处输入图像描述"
Window6,使用资源字典 Dictionary1 中的 WindowChrome 样式。
里面有一个大的圆形关闭按钮。但是在下载之前给你一个想法:
<Style x:Key="FinishedWindow" TargetType="{x:Type Window}">
<Setter Property="FontFamily" Value="Comic Sans MS"/>
<Setter Property="Foreground" Value="{StaticResource DarkDark}"/>
<Setter Property="WindowChrome.WindowChrome">
<Setter.Value>
<WindowChrome CaptionHeight="0"
CornerRadius="20"
GlassFrameThickness="0"
NonClientFrameEdges="None"
ResizeBorderThickness="5"
/>
</Setter.Value>
</Setter>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Window}">
<Grid>
<Border Background="{StaticResource BrightMid}" BorderBrush="{StaticResource DarkLight}" BorderThickness="4,4,6,6"
CornerRadius="12">
<Border.Effect>
<BlurEffect KernelType="Gaussian" Radius="12" RenderingBias="Quality" />
</Border.Effect>
</Border>
<Border BorderBrush="{StaticResource DarkDark}" BorderThickness="2"
CornerRadius="12" ClipToBounds="True">
</Border>
<Grid>
<Grid.RowDefinitions>
<RowDefinition Height="32"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<TextBlock Text="{Binding RelativeSource={RelativeSource TemplatedParent}, Path=Title}"
Foreground="{StaticResource DarkDark}"
Grid.Row="0"
HorizontalAlignment="Center"
VerticalAlignment="Bottom"
FontWeight="Bold"
FontSize="16"
/>
<Button Name="CloseButton"
Width="20" Height="20"
Grid.Row="0"
HorizontalAlignment="Right"
BorderThickness="0"
Margin="0,12,12,0"
Command="{Binding RelativeSource={RelativeSource TemplatedParent}, Path=CloseCommand}"
Style="{StaticResource CloseButton}"/>
<ContentPresenter Grid.Row="1" Margin="12"/>
</Grid>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
我试了一下你的风格。
只是隐含地使用它根本没有任何效果。
我把它放在 app.xaml 中并给它一个密钥
<Application.Resources>
<Style TargetType="{x:Type Window}" x:Key="roundedWindowStyle">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Window}">
<Grid>
<Border
x:Name="RoundMask"
CornerRadius="10"
Background="white"/>
<!-- The main content -->
<Grid>
<Grid.OpacityMask>
<VisualBrush Visual="{Binding ElementName=RoundMask}" />
</Grid.OpacityMask>
</Grid>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</Application.Resources>
然后我将它应用到主窗口
<Window
...
Title="MainWindow"
Style="{StaticResource roundedWindowStyle}"
按 f5 ......它有点工作。好。
如果您忽略该窗口镶边,则意味着它无法按您的预期工作。
data:image/s3,"s3://crabby-images/9846b/9846b60a00e95a937d6b04f6d7f948d92d853d3c" alt="在此处输入图像描述"
您可能应该考虑使用窗口镶边。
用你那里的东西。
至少,您需要在该网格内有一个 Contentpresenter。因为窗口是一个内容控件,但如果模板中没有 contentpresenter,它根本不会显示任何内容。