(二)WPF使用 Polyline 元素动态绘制折线(每秒钟移动视图)

上一个程序的运行结果,会不断随机产生数据并且自动绘制直线,但是折线图不会移动,稍微修改一下上一个程序即可轻松实现折线图移动。前段代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Windows.Threading;

namespace 使用_Polyline_元素来绘制折线
{
    /// <summary>
    /// MainWindow.xaml 的交互逻辑
    /// </summary>
    public partial class MainWindow : Window
    {
        private int currentSecond = 0;
        Random rd = new Random();
        private DispatcherTimer dispatcherTimer = new DispatcherTimer();
        public MainWindow()
        {
            InitializeComponent();
        }

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            dispatcherTimer.Interval = TimeSpan.FromMilliseconds(1000);//1秒钟产生一次中断
            dispatcherTimer.Tick += timer_Tick;//中断入口函数
            dispatcherTimer.IsEnabled = true;//开启中断
        }

        private void timer_Tick(object sender, EventArgs e)
        {
            currentSecond++;
            double x = currentSecond * 10;
            double y = rd.Next(1,200);
                    
            var point = new Point(x, y);
            _myPolyline.Points.Add(point);//添加新的数据点

            if (currentSecond > 10 )
            {
                _myPolyline.Points.RemoveAt(0);//移除数据点索引0的位置
                _myCanvas.Margin = new Thickness(-20 * currentSecond+500, 0, 0, 0);
            }
        }
    }
}
 

如果不移除数据点索引0的位置,程序依然会运行,但是随着运行时间的增加,内存会不断增加,CPU使用率也会不断增加

 

XAML代码如下:

<Window x:Class="使用_Polyline_元素来绘制折线.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"
        xmlns:local="clr-namespace:使用_Polyline_元素来绘制折线"
        mc:Ignorable="d"
        Title="MainWindow" Height="450" Width="800">
    <Canvas Name="_myCanvas" Height="400" Width="400">
        <Polyline Name="_myPolyline"
            Stroke="Black"
            StrokeThickness="4" />
        <Button Content="开始" Canvas.Left="-190" Canvas.Top="47" Width="75" Click="Button_Click" HorizontalAlignment="Left"/>
    </Canvas>
</Window>

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值