记录|C# winform——Chart控件

2024-08-24 09:20

本文主要是介绍记录|C# winform——Chart控件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 前言
  • 一、重点关注
    • 1.1 Chart控件效果
    • 1.2 属性
      • 1.2.0 位置讲解
      • 1.2.1 Titles——标题集合
        • Text
        • ToolTip
      • 1.2 .2 Series——图表序列
        • ChartType
        • Legends——图例集合
  • 二、数据传入Chart控件
    • 2.1 如何传入数据?
    • 2.2 如果想限定每次展现的数据量怎么办?
  • 三、标注每个点的值
    • 3.1 如何在图表中标出每个点的值?
      • 可视化理解
      • 代码编写
      • 效果展示
  • 四、多个Chart控件演示【只是演示的时候方便】
  • 更新时间


前言

参考视频:
零基础C#教程037期 winform大数据Chart图形开发技巧


一、重点关注

1.1 Chart控件效果

在这里插入图片描述

1.2 属性

下图中的都是集合
在这里插入图片描述
比较重要的是:标题、序列、图例

1.2.0 位置讲解

在这里插入图片描述

1.2.1 Titles——标题集合

这个是Chart控件中的属性。是个集合。
集合中的每个成员都是控件。

Text

Titles集合里面的每个成员都是个Title控件。【如下图】
在这里插入图片描述
效果如下图:
在这里插入图片描述

ToolTip
  • 用于制作提示信息,需要鼠标移动上时触发【效果如下:】
    在这里插入图片描述

1.2 .2 Series——图表序列

在这里插入图片描述
序列,就是数据展示的形式。可以是柱状图、折线图、散点图。

ChartType
  • 选择序列展现的形式。有柱状图、折线图、散点图。
    在这里插入图片描述
Legends——图例集合
  • 这里配置图例的颜色和展现样式

二、数据传入Chart控件

2.1 如何传入数据?

  • 首先,需要在Form的Load()方法中进行配置。
  • 其次调用Point.Add()就可以实现添加数据
    简单的代码如下:
        private void Form1_Load(object sender, EventArgs e){for(int i = 0; i < 10; i++){Random rdom = new Random();chart1.Series[0].Points.Add(rdom.Next(0,101));}}
  • 运行后效果如下:
    在这里插入图片描述
  • 可以添加个Timer触发器,让图中的数据动态移动展示。【如下图】
    在这里插入图片描述

2.2 如果想限定每次展现的数据量怎么办?

如果数据如下图中,每次都在不断增加,但是窗体有限,结果很拥挤,需要对每次展现的数据量进行控制怎么办?
在这里插入图片描述
-下面代码是:每次只展示10个点的作用

        private void timer1_Tick(object sender, EventArgs e){//当前图例展示的数据数量到到达10个时,将第一个移除,再添加一个点if (chart1.Series[0].Points.Count == 10){chart1.Series[0].Points.RemoveAt(0);}Random rdom = new Random();chart1.Series[0].Points.Add(rdom.Next(0, 101));}
  • 效果如下:
    在这里插入图片描述

三、标注每个点的值

3.1 如何在图表中标出每个点的值?

可视化理解

先在Chart控件中,找到Series集合。
在里面找到Points集合【如下图】
在这里插入图片描述
在Point中创建个DataPoint对象。
XValues+YValues能指定展示的位置
Label:显示展示的点的值。
在这里插入图片描述

代码编写

基于上面的可视化理解后,下面的代码就好理解了。

        private void timer1_Tick(object sender, EventArgs e){//当前图例展示的数据数量到到达10个时,将第一个移除,再添加一个点if (chart1.Series[0].Points.Count == 10){chart1.Series[0].Points.RemoveAt(0);}Random rdom = new Random();int current_point = rdom.Next(0, 101);DataPoint dataPoint = new DataPoint();dataPoint.YValues = new double[] { current_point };dataPoint.Label = current_point.ToString();chart1.Series[0].Points.Add(dataPoint);}

效果展示

在这里插入图片描述

四、多个Chart控件演示【只是演示的时候方便】

  • 作用:演示的时候,用一组数据去控制多个Chart控件的展示。【代码如下:】
        private void timer1_Tick(object sender, EventArgs e){for (int i = 1; i <= 4; i++) {Chart chartList = tableLayoutPanel1.Controls.Find("chart" + i.ToString(), true)[0] as Chart;//当前图例展示的数据数量到到达10个时,将第一个移除,再添加一个点if (chartList.Series[0].Points.Count == 10){chartList.Series[0].Points.RemoveAt(0);}Random rdom = new Random();int current_point = rdom.Next(0, 101);DataPoint dataPoint = new DataPoint();dataPoint.YValues = new double[] { current_point };dataPoint.Label = current_point.ToString();chartList.Series[0].Points.Add(dataPoint);}}

注意:tableLayoutPanel1.Controls.Find(“chart” + i.ToString(), true)——Find()方法中的true表示是找Panel中的子控件

  • 效果:
    在这里插入图片描述

更新时间

  • 2024.08.23:创建

这篇关于记录|C# winform——Chart控件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1102076

相关文章

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

lvgl8.3.6 控件垂直布局 label控件在image控件的下方显示

在使用 LVGL 8.3.6 创建一个垂直布局,其中 label 控件位于 image 控件下方,你可以使用 lv_obj_set_flex_flow 来设置布局为垂直,并确保 label 控件在 image 控件后添加。这里是如何步骤性地实现它的一个基本示例: 创建父容器:首先创建一个容器对象,该对象将作为布局的基础。设置容器为垂直布局:使用 lv_obj_set_flex_flow 设置容器

学习记录:js算法(二十八):删除排序链表中的重复元素、删除排序链表中的重复元素II

文章目录 删除排序链表中的重复元素我的思路解法一:循环解法二:递归 网上思路 删除排序链表中的重复元素 II我的思路网上思路 总结 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 图一 图二 示例 1:(图一)输入:head = [1,1,2]输出:[1,2]示例 2:(图

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

C# 防止按钮botton重复“点击”的方法

在使用C#的按钮控件的时候,经常我们想如果出现了多次点击的时候只让其在执行的时候只响应一次。这个时候很多人可能会想到使用Enable=false, 但是实际情况是还是会被多次触发,因为C#采用的是消息队列机制,这个时候我们只需要在Enable = true 之前加一句 Application.DoEvents();就能达到防止重复点击的问题。 private void btnGenerateSh