4

パスとポリラインのWPFでのレンダリングが異なるのはなぜですか?

これはコードとブレンドの両方で発生しています。何かが足りないか、これは単なるアンチエイリアシング効果です。

<Window
 xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
 xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
 x:Class="GeometryMonky.Window1"
 x:Name="Window"
 Title="Window1"
 Width="640" Height="480" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" mc:Ignorable="d">

 <Grid x:Name="LayoutRoot">
  <Path Fill="#FFFFFFFF" Stretch="Fill" Stroke="#FF0000FF" Margin="100,10,0,0" Data="M289,39 L333,173" Width="1" HorizontalAlignment="Left" Height="100" StrokeThickness="1"/>

  <Polyline Stroke="#FF0000FF" Margin="115,178,417,168" StrokeThickness="1" Width="100" Height="100">
   <Polyline.Points>
    <Point>10,0</Point>
    <Point>10,100</Point>
   </Polyline.Points>
  </Polyline>
 </Grid>
</Window>

Blendからの画像サンプル:http: //img190.imageshack.us/img190/2965/wpfsmaple.png

開発システム:WinXP SP2、VS 2008 + SP1

4

2 に答える 2

3

これを Path または Polyline xaml タグに入れます

RenderOptions.EdgeMode="Aliased"
于 2013-04-19T20:50:10.997 に答える
3

これは、テキスト以外のオブジェクトの描画モードに関係しています。以下にリンクされている記事のようにポリラインオブジェクトを設定してみましたが、パスのように見えます。

つまり、簡単な答えは、アンチエイリアシングに関係しているということです。記事は次のとおりです:単一ピクセル線

ここにコマンドが必要な場合は、ポリラインに名前を付けてから、コードビハインドに次を追加します。

public partial class MainWindow : Window
{
    public MainWindow()
    {
        this.InitializeComponent();
        // THIS IS THE LINE THATS IMPORTANT
        pLine.SetValue(RenderOptions.EdgeModeProperty, EdgeMode.Aliased);
   }
}

ここで xaml を変更します。

<Polyline x:Name="pLine" Stroke="#FF0000FF" Margin="115,178,417,168" StrokeThickness="1" Width="100" Height="100">
  <Polyline.Points>
    <Point>10,0</Point>
    <Point>10,100</Point>
   </Polyline.Points>
</Polyline>

これにより、ポリライン オブジェクトが Path オブジェクトのように見えます。ただし、未指定を使用するようにパスを変更しても何も起こらないため、他のオブジェクトをパスと同じように見せることはできますが、その逆はできません。

于 2010-01-14T19:07:01.453 に答える