網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
前言
在做項(xiàng)目的時(shí)候,遇到一個(gè)需求,需要我對(duì)Chart圖標(biāo)標(biāo)記數(shù)據(jù)正在運(yùn)行,實(shí)現(xiàn)數(shù)據(jù)可視化,因?yàn)槲覀兊谋砀袷请[藏Y軸的刻度是看不到數(shù)據(jù)值的,于是采用數(shù)據(jù)標(biāo)記的形式來(lái)動(dòng)態(tài)展示值,那么我們應(yīng)該怎么去處理這個(gè)問(wèn)題呢,閱讀這篇文章吧,我們一起學(xué)習(xí)學(xué)習(xí)一下,創(chuàng)作不易,大家點(diǎn)贊關(guān)注評(píng)論收藏,你的點(diǎn)贊和關(guān)注是我創(chuàng)作的動(dòng)力,也是我持續(xù)不斷學(xué)習(xí)的動(dòng)力。謝謝大家啦!!!
效果展示
先來(lái)展示一下我們的效果,看看是怎么回事,在看看有沒(méi)有欲望往下面看看文章,主要是對(duì)Chart圖的標(biāo)記問(wèn)題做了處理,我們使用了Chart控件的一個(gè)對(duì)Point點(diǎn)的設(shè)置實(shí)現(xiàn)這種動(dòng)態(tài)展示Chart圖的標(biāo)記,兩張圖的效果對(duì)比非常明顯,對(duì)于我們 有這樣的需求的項(xiàng)目可以采用這樣的形式,或者采用另一種的鼠標(biāo)點(diǎn)擊彈出提示,下篇文章應(yīng)該會(huì)寫出來(lái)和大家一起學(xué)習(xí)一下,大家多點(diǎn)贊,我創(chuàng)作的動(dòng)力更強(qiáng)。
解決方法
我們來(lái)看一下解決的方法,我使用Chart控件里面對(duì)Point的MarkerStyle 進(jìn)行標(biāo)記,實(shí)現(xiàn)這樣的方式,對(duì)MarkerStyle 的樣式設(shè)置標(biāo)記大小,標(biāo)記顏色,以及標(biāo)記展示的值,使用的是隨機(jī)函數(shù)產(chǎn)生的數(shù)據(jù),生成的表格,對(duì)表格的數(shù)據(jù)添加,然后在對(duì)這個(gè)點(diǎn)進(jìn)行標(biāo)記,只標(biāo)記最新是使用標(biāo)一個(gè)去一個(gè)的方式,就是我把最新的標(biāo)記好,把上一個(gè)去掉標(biāo)記,哪個(gè)按鈕我只給了一個(gè)狀態(tài)值讓它去判斷是最新還是一直標(biāo)記,也可以加個(gè)狀態(tài)不標(biāo)記。后面貼了代碼你們可以后期自己二次更新。
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Windows.Forms.DataVisualization.Charting;
namespace TestIC00
{
public partial class Form2 : Form
{
public Form2()
{
InitializeComponent();
}
private void Form2_Load(object sender, EventArgs e)
{
}
public int index = 0;
public bool flag = false;
private void button1_Click(object sender, EventArgs e)
{
timer1.Enabled = !timer1.Enabled;//對(duì)定時(shí)器的操作,點(diǎn)擊打開(kāi)或關(guān)閉定時(shí)器,主要是實(shí)現(xiàn)一秒傳一個(gè)值
}
private void timer1_Tick(object sender, EventArgs e)
{
Random random = new Random();
this.chart1.ChartAreas[0].AxisX.MajorGrid.Interval = 1;//網(wǎng)格間隔
this.chart1.ChartAreas[0].AxisX.MinorGrid.Interval = 1;
this.chart1.ChartAreas[0].AxisY.MajorGrid.Interval = 1;//網(wǎng)格間隔
this.chart1.ChartAreas[0].AxisY.MinorGrid.Interval = 1;
this.chart1.ChartAreas[0].AxisX.LabelStyle.Interval = 1;//設(shè)置X軸的值的間隔大小
this.chart1.ChartAreas[0].AxisX.MajorGrid.LineColor = Color.Gray;//設(shè)置X軸網(wǎng)格線顏色
this.chart1.ChartAreas[0].AxisY.MajorGrid.LineColor = Color.Gray;//設(shè)置Y軸網(wǎng)格線顏色
chart1.ChartAreas[0].AxisX.ScrollBar.Enabled = true;//啟動(dòng)滾動(dòng)條
this.chart1.ChartAreas[0].AxisY.LabelStyle.Enabled = false;//使Y軸的刻度隱藏
chart1.ChartAreas[0].AxisX.ScaleView.Scroll(System.Windows.Forms.DataVisualization.Charting.ScrollType.Last);//啟用視圖實(shí)現(xiàn)數(shù)據(jù)滾動(dòng)
int value = random.Next(0, 20);//產(chǎn)生隨機(jī)數(shù)進(jìn)行賦值
chart1.Series[0].Points.AddY(value);//對(duì)折線圖添加數(shù)據(jù)
if(flag)//判斷標(biāo)記,如果是true表示只標(biāo)記最新,需要去掉前面的一個(gè)值
{
this.chart1.Series[0].Points[index].MarkerStyle = MarkerStyle.Circle;//設(shè)置標(biāo)記的形狀為圓形
this.chart1.Series[0].Points[index].MarkerColor = Color.Red;//形狀顏色設(shè)置
this.chart1.Series[0].Points[index].MarkerBorderWidth = 3;//形狀大小設(shè)置
this.chart1.Series[0].Points[index].MarkerSize = 10;//設(shè)置我們展示標(biāo)記的大小
this.chart1.Series[0].Points[index].Label = "功能:" + this.chart1.Series[0].Name + "\r\n" + "值:" + value.ToString();//對(duì)標(biāo)記展示的值
this.chart1.Series[0].Points[index].IsValueShownAsLabel = true;//展示標(biāo)記
this.chart1.Series[0].Points[index-1].MarkerBorderWidth = 0;//改前一個(gè)標(biāo)記的大小
this.chart1.Series[0].Points[index - 1].MarkerSize = 0;//形狀大小
this.chart1.Series[0].Points[index - 1].Label = "";//展示數(shù)據(jù)
this.chart1.Series[0].Points[index - 1].IsValueShownAsLabel = false;//不展示
}
else//對(duì)數(shù)據(jù)一直標(biāo)記
{
this.chart1.Series[0].Points[index].MarkerStyle = MarkerStyle.Circle;
this.chart1.Series[0].Points[index].MarkerColor = Color.Red;
this.chart1.Series[0].Points[index].MarkerBorderWidth = 3;
this.chart1.Series[0].Points[index].MarkerSize = 10;
this.chart1.Series[0].Points[index].Label = "功能:" + this.chart1.Series[0].Name + "\r\n" + "值:" + value.ToString();
this.chart1.Series[0].Points[index].IsValueShownAsLabel = true;
}
//也可以加一種狀態(tài)是什么也不標(biāo)記,你們自己對(duì)那個(gè)狀態(tài)值的處理就可以啦
index++;
}
private void button2_Click(object sender, EventArgs e)//只標(biāo)記最新按鈕
{
flag = !flag;//對(duì)狀態(tài)值的改變,我就使用了兩種狀態(tài),你們可以改
}
}
}
總結(jié)
這篇文章主要是對(duì)博主遇到的一個(gè)問(wèn)題的一種簡(jiǎn)單的解決辦法,雖然很簡(jiǎn)單,但是還是有技術(shù)含量的,C#的問(wèn)題太多了,而去解決的人太少,我們要懂得分享,而我們發(fā)文章的人太少啦,所以我把我遇到的一些問(wèn)題的解決辦法發(fā)出來(lái),讓大家指點(diǎn)我一下,我們一起學(xué)習(xí)一下,當(dāng)然還有別的方法,別的方法是用鼠標(biāo)點(diǎn)擊展示
原文鏈接:https://juejin.cn/post/7132818750155259912
相關(guān)推薦
- 2022-10-18 linux下shell腳本備份文件的方法實(shí)現(xiàn)_linux shell
- 2022-04-22 element的el-drawer預(yù)留操作欄問(wèn)題
- 2022-12-29 基于R語(yǔ)言時(shí)間序列的平穩(wěn)時(shí)間序列模型預(yù)測(cè)圖文詳解_R語(yǔ)言
- 2022-11-12 C++中的數(shù)組、鏈表與哈希表_C 語(yǔ)言
- 2022-04-24 C語(yǔ)言時(shí)間函數(shù)之strftime()詳解_C 語(yǔ)言
- 2022-11-24 Python文件簡(jiǎn)單操作及openpyxl操作excel文件詳解_python
- 2022-07-13 VMware安裝VMware Tools失敗/安裝不了,無(wú)網(wǎng)絡(luò)離線安裝
- 2022-04-14 如何解決error: failed to push some refs to ‘xxx(遠(yuǎn)程庫(kù))‘
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支