Chinaunix首页 | 论坛 | 博客
  • 博客访问: 6642902
  • 博文数量: 915
  • 博客积分: 17977
  • 博客等级: 上将
  • 技术积分: 8846
  • 用 户 组: 普通用户
  • 注册时间: 2005-08-26 09:59
个人简介

一个好老好老的老程序员了。

文章分类

全部博文(915)

文章存档

2022年(9)

2021年(13)

2020年(10)

2019年(40)

2018年(88)

2017年(130)

2015年(5)

2014年(12)

2013年(41)

2012年(36)

2011年(272)

2010年(1)

2009年(53)

2008年(65)

2007年(47)

2006年(81)

2005年(12)

分类: C#/.net

2013-06-26 11:34:48

在使用WPF画横纵坐标图,可以使用本身的Canvas下实现。默认坐标原点在左上角。能过下面的实现可以实现在左正解,并连续曲线图,不过比不上DynamicDataDisplay的效果美观。
首先在Xaml中定义Canvas。如下:

点击(此处)折叠或打开

  1. <Border BorderBrush="Black" BorderThickness="1" Height="200" Width="200">
  2.             <Canvas Height="200" Width="200" x:Name="Canvas1">
  3.                 <Canvas.RenderTransform>
  4.                     <TransformGroup>
  5.                         <ScaleTransform ScaleY="-1" />
  6.                         <TranslateTransform Y="200" />
  7.                     </TransformGroup>
  8.                 </Canvas.RenderTransform> </Canvas>
  9.         </Border>
设置Canvas是正方形,200长。
在窗体的Page_Load事件中添加画线:

点击(此处)折叠或打开

  1. private void Window_Loaded(object sender, RoutedEventArgs e)
  2.         {
  3.             int[] slices = new int[67];
  4.             for (int i = 0; i < 67; i++)
  5.             {
  6.                 slices[i] = i*3;
  7.             }
  8.             double[] sens = new double[67];
  9.             sens[0] = 0;
  10.             sens[66] = 0;
  11.             for (int i = 1; i < 66; i++)
  12.             {
  13.                 if (i % 2 == 0)
  14.                 {
  15.                     sens[i] = 119.8 + 20;
  16.                 }
  17.                 else
  18.                 {
  19.                     sens[i] = 119.8 - 20;
  20.                 }
  21.             }
  22.             for (int i = 0; i < 66; i++)
  23.             {
  24.                 Line line = new Line();
  25.                 line.X1 = slices[i];
  26.                 line.Y1 = sens[i];
  27.                 line.X2 = slices[i + 1]+1;
  28.                 line.Y2 = sens[i + 1];
  29.                 line.Stroke = System.Windows.Media.Brushes.Black;
  30.                 line.StrokeThickness = 1;
  31.                 this.Canvas1.Children.Add(line);
  32.             }
  33.         }
其中:line.Stroke = System.Windows.Media.Brushes.Black;很重要,如果没有这行,画出的线条都是白色的。
line.StrokeThickness = 1;设置线条的粗细。
效果图如下:

 


阅读(9282) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~