记录|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

相关文章

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和