c# - 混叠问题

标签 c# wpf xaml vector-graphics

下面的代码在 Canvas 上绘制两条垂直线。这些线条在屏幕上看起来粗细不同,尽管它们在代码中是相同的。我想找到一种方法让它们看起来像 Canvas 周围的边框一样清晰。设置 Path.SnapsToDevicePixels 没有任何效果。该代码是一个人为的示例,通常绘制这些线的 Canvas 可以嵌套在可视化树的更深处。

感谢您的帮助 康斯坦丁


<Window x:Class="wpfapp.MyWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
  <Grid>
    <Border BorderBrush="Black"
            BorderThickness="1"
            Margin="10">
      <Canvas x:Name="Canvas"
              SizeChanged="OnCanvasSizeChanged" />
    </Border>
  </Grid>
</Window>

using System.Windows;
using System.Windows.Media;
using System.Windows.Shapes;

namespace wpfapp
{
    public partial class MyWindow : Window
    {
        public MyWindow()
        {
            InitializeComponent();
        }

        private void OnCanvasSizeChanged(object sender, SizeChangedEventArgs e)
        {
            StreamGeometry g = new StreamGeometry();
            double h = this.Canvas.ActualHeight;

            using (StreamGeometryContext c = g.Open())
            {
                c.BeginFigure(new Point(7, 0), false, false);
                c.LineTo(new Point(7, h), true, false);

                c.BeginFigure(new Point(14, 0), false, false);
                c.LineTo(new Point(14, h), true, false);
            }
            g.Freeze();

            Path p = new Path();

            p.Data = g;
            p.SnapsToDevicePixels = true;
            p.Stroke = new SolidColorBrush(Colors.Black);
            p.StrokeThickness = 1;

            this.Canvas.Children.Clear();
            this.Canvas.Children.Add(p);
        }
    }
}

最佳答案

需要使用GuidelineSet:


        protected override void OnRender(DrawingContext c)
        {
            base.OnRender(c);

            Pen pen = new Pen(Brushes.Black, 1);
            double h = this.ActualHeight;
            double d = pen.Thickness / 2;

            foreach (double x in new double[] { 7, 14 })
            {
                GuidelineSet g = new GuidelineSet(new double[] { x + d },
                                                  new double[] { 0 + d, h + d });

                c.PushGuidelineSet(g);
                c.DrawLine(pen, new Point(x, 0), new Point(x, h));
                c.Pop();
            }
        }

关于c# - 混叠问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4034279/

相关文章:

c# - WPF Infragistics XamDataGrid 窃取滚动焦点

WPF:绑定(bind)到自定义结构

c# - 使用集合时如何在MVVM中同步数据

c# - 数据绑定(bind)到 C# XAML 中的集线器部分

c# - 本地化绑定(bind)

c# - Azure Key Vault secret 访问间歇性无法连接并出现套接字异常

c# - 如何使用 Quartz.net 和 log4net 配置 ninject

c# - 在带有参数的winforms webbrowser控件中从JS调用C#方法时出错

c# - WPF Caliburn Micro Message.Attach 未通过 HierarchicalDataTemplate 冒泡

c# - 在多列中显示 ComboBoxItems