次のコードなぜwpfでボーダーのボーダーとボーダーの背景の間にギャップがありますか?
<Window x:Class="WpfApp1.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"
mc:Ignorable="d"
Title="MainWindow" Height="350" Width="525">
<Grid>
<Border Background="Red">
<Border BorderThickness="10" BorderBrush="Black" Background="Black"/>
</Border>
</Grid>
</Window>
は、以下の出力を生成(.NET 4.6.1、Windowsの10):
赤いラインがあってはなりません。それは、第2ボーダーのボーダーと第2ボーダーの背景との間のギャップのようです。 SnapsToDevicePixels
をTrue
に設定しようとしましたが、変更されません。
UPDATE
の回答で示唆したように、RenderOptions.EdgeMode="Aliased"
は、問題を解決しているようです。しかし、実際には、WPFのバグを強調する方が良いと思います。今あるので、次のコード:
<Window x:Class="WpfApp1.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"
mc:Ignorable="d"
RenderOptions.EdgeMode="Aliased"
SnapsToDevicePixels="True"
Title="MainWindow" Height="350" Width="525">
<Grid>
<Border Background="Red">
<Border Margin="10" BorderThickness="1" BorderBrush="Black">
<Grid Background="Black"/>
</Border>
</Border>
</Grid>
</Window>
WPFプロジェクトでコードをコピーしましたが、その赤い線が表示されませんでした。あなたのビジュアルを変更することがあります。質問を単純化するためにすべてのコードを含めなかったと思います。 – Tuco
私はVS2015の新しいプロジェクトにコピーしてそこに現れます。編集:デザインモードのみ、私はそれを実行すると赤はありません。 –
あなたはW10を使用していますが、私は@AdamSillsも使用していると思います.W7を使用していますので、OSがビジュアルをどのように扱うかについては、私はそのフィールドを無視しています – Tuco