C#?Chart控件標(biāo)記問題詳解
前言
在做項(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)記的形式來動(dòng)態(tài)展示值,那么我們應(yīng)該怎么去處理這個(gè)問題呢,閱讀這篇文章吧,我們一起學(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)力。謝謝大家啦!??!
效果展示
先來展示一下我們的效果,看看是怎么回事,在看看有沒有欲望往下面看看文章,主要是對(duì)Chart圖的標(biāo)記問題做了處理,我們使用了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ì)寫出來和大家一起學(xué)習(xí)一下,大家多點(diǎn)贊,我創(chuàng)作的動(dòng)力更強(qiáng)。
解決方法
我們來看一下解決的方法,我使用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)擊打開或關(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è)問題的一種簡(jiǎn)單的解決辦法,雖然很簡(jiǎn)單,但是還是有技術(shù)含量的,C#的問題太多了,而去解決的人太少,我們要懂得分享,而我們發(fā)文章的人太少啦,所以我把我遇到的一些問題的解決辦法發(fā)出來,讓大家指點(diǎn)我一下,我們一起學(xué)習(xí)一下,當(dāng)然還有別的方法,別的方法是用鼠標(biāo)點(diǎn)擊展示
到此這篇關(guān)于C# Chart控件標(biāo)記問題詳解的文章就介紹到這了,更多相關(guān)C# Chart控件標(biāo)記內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#?App.config和Web.config加密的實(shí)現(xiàn)步驟
本文介紹了如何使用C#對(duì)App.config和Web.config文件進(jìn)行加密,通過使用ConfigurationSection類和SymmetricAlgorithm類,我們可以保護(hù)配置文件中的敏感數(shù)據(jù),確保只有授權(quán)人員可以訪問2023-08-08詳解c# 強(qiáng)制轉(zhuǎn)換和類型轉(zhuǎn)換
這篇文章主要介紹了c# 強(qiáng)制轉(zhuǎn)換和類型轉(zhuǎn)換的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)c#,感興趣的朋友可以了解下2020-10-10