C#生成餅形圖及添加文字解釋實例代碼。本站提示廣大學習愛好者:(C#生成餅形圖及添加文字解釋實例代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是C#生成餅形圖及添加文字解釋實例代碼正文
本文以實例情勢解釋了C#生成餅形圖,圓餅圖,並為圖表添加文字正文的辦法。可完成文字顯示在圖表四周,直不雅抽象的展現各個數據重量的走拋情形的後果。平日在編寫體系報表進程中,應用圖表顯示數據是許多人承認的方法。本文所述的就是一個用Visual C#生成圓餅型圖表,而且在圖表核心添加數據重量報表解釋的一個例子。
詳細功效代碼以下:
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace 在餅型圖的核心顯示解釋文字 { public partial class Form1 : Form { public Form1() { InitializeComponent(); } public static string[] XText = new string[7] { "商品1", "商品2", "商品3", "商品4", "商品5", "商品6", "商品7" };//存儲數據的稱號數組 public static float[] SzData = new float[7] { 5F, 17F, 7F, 2F, 10F, 5F, 4F };//獲得每列的和 public static Color[] WearColor = new Color[] { Color.Red,Color.Gold,Color.Chartreuse,Color.Teal,Color.RoyalBlue,Color.Fuchsia,Color.Firebrick, Color.Goldenrod,Color.ForestGreen,Color.Aqua,Color.Blue,Color.PaleVioletRed,Color.Salmon,Color.Yellow,Color.LimeGreen,Color.LightBlue,Color.LightSteelBlue,Color.MediumPurple}; public static string[] AreaText;//暫時存儲數據的稱號數組 Pen mypen; float AreaAngle = 0F; public static float XSize = 50;//X軸的年夜小 public static float YSize = 50;//Y軸的年夜小 public static float ASum=50;//記載餅形的總和 public static float TemXSize = 0;//X軸的暫時年夜小 public static float XLeft = 0;//X軸的左端點 public static float XRight = 0;//X軸的右端點 public static float YUp = 0;//Y軸的上端點 public static float YDown = 50;//Y軸的下端點 public static SolidBrush mybrush = new SolidBrush(Color.Red); public static float Aline = 20;//標識文字的前端線長 public static float Asash = 3;//標識文本名邊框的寬度 public static float temXLeft = 0;//X軸的左端點初始化 #region 繪制餅形圖(Area) public static float AreaXMaxWidth = 0;//獲得字符串的寬度 public static float AreaXMaxHeight = 0;//獲得字符串的高度 //獲得餅形圖的標識文字 public void AreaValue() { string temTextSize = "";//存儲最長的稱號 Font LSfont = new System.Drawing.Font("宋體", 8);//設置解釋文字的字體 AreaText = new string[XText.Length];//實例化一個暫時數組 for (int i = 0; i < AreaText.Length; i++)//獲得稱號 { AreaText[i] = XText[i]; } float AresF = 0;//記載百分比 for (int i = 0; i < AreaText.Length; i++)//經由過程稱號及百分比,組合解釋文字 { AresF = (SzData[i] / ASum) * 100;//獲得以後記載的百分比 AresF = (float)Math.Round(AresF, 3);//對百分比停止四捨五入 AreaText[i] = AreaText[i] + " " + AresF.ToString() + "%";//組合解釋文字 if (AreaText[i].Length > temTextSize.Length)//獲得最長的解釋文件 temTextSize = AreaText[i]; } Graphics TitG = this.CreateGraphics();//創立Graphics類對象 SizeF XMaxSize = TitG.MeasureString(temTextSize + Asash * 2, LSfont);//將繪制的字符串停止格局化 AreaXMaxWidth = XMaxSize.Width;//獲得字符串的寬度 AreaXMaxHeight = XMaxSize.Height;//獲得字符串的高度 } //繪制餅形圖表 public void ProtractArea(Graphics g) { AreaValue();//盤算最長解釋文字的年夜小 //初始化變量 mypen = new Pen(Color.Black, 1);//設置畫筆的色彩及年夜小 float f = 0;//記載百分比 float TimeNum = 0;//扇形的繪軌制數 float AXLeft = 0;//設置餅形圖的X坐標 float AYUp = 0;//設置餅形圖的Y坐標 float AXSize = 0;//設置餅形圖的寬度 float AYSize = 0;//設置餅形圖的高度 float Atop = 0;//記載餅形的高度為長和寬的最小值 float Aleft = 0;//記載餅形的高度為長和寬的最小值 TimeNum = AreaAngle;//設置餅形圖的肇端度數 //盤算餅形圖的初始地位 XLeft = panel1.Width - (panel1.Width - 5);//去了邊框後餅形圖的X地位 XSize = panel1.Width - 10;//設置餅形圖的寬度 temXLeft = AXLeft;//記載餅形圖的X坐標 AXLeft = XLeft;//記載餅形圖的X坐標 AXSize = XSize;//記載餅形圖的寬度 //經由過程解釋文字的年夜小盤算餅形圖的地位 AXLeft = AXLeft + AreaXMaxWidth + Aline;//設置去除解釋文字後的餅形圖X坐標 AYUp = AYUp + AreaXMaxHeight;//設置去除解釋文字後的餅形圖Y坐標 AXSize = XSize - AreaXMaxWidth * 2 - Aline * 2;//設置去除解釋文字後的餅形圖寬度 AYSize = YSize - AreaXMaxHeight * 2;//設置去除解釋文字後的餅形圖高度 if (AXSize >= AYSize)//假如餅形圖的寬度年夜於等於高度 { Aleft = AXSize - AYSize;//記載餅形圖的X坐標 AXSize = AYSize;//將高度設為寬度 } else { Atop = AYSize - AXSize;//記載餅形圖的Y坐標 AYSize = AXSize;//將寬度設為高度 } if (Aleft != 0)//假如廣大於高 { AXLeft = AXLeft + Aleft / 2;//設置餅形圖橫向局中 } if (Atop != 0)//假如嵬峨於寬 { AYUp = AYUp + Atop / 2;//設置餅形圖縱向局中 } temXLeft = XLeft; //繪制餅形圖 if (AXSize > 0 && AYSize > 0)//假如餅形圖的寬和嵬峨於0 { for (int i = 0; i < SzData.Length; i++)//遍歷數據 { f = SzData[i] / ASum;//獲得以後數據的百分比 //設置以後扇形圖的填充色彩 if (i >= WearColor.Length)//假如沒有超越色彩數組 mybrush = new SolidBrush(WearColor[i - WearColor.Length]); else mybrush = new SolidBrush(WearColor[i]); g.FillPie(mybrush, AXLeft, AYUp, AXSize, AYSize, TimeNum, f * 360);//繪制扇形圖 TimeNum += f * 360;//設置下一個扇形圖的度數 } ProAreaSign(g);//繪制餅形圖的解釋文字 } else return; } #endregion #region 繪制餅形圖標識(Area) public void ProAreaSign(Graphics g) { AreaValue();//存儲最長的稱號 mypen = new Pen(Color.Black, 1);//設置畫筆的色彩及年夜小 Font LSfont = new System.Drawing.Font("宋體", 8);//設置解釋文字的字體款式 SolidBrush Zbrush = new SolidBrush(Color.Black);//設置寄存解釋文字邊框的畫刷 SolidBrush ATbrush = new SolidBrush(Color.Khaki);//設置寄存解釋文字方塊的配景畫刷 //初始化變量 float f = 0;//記載百分比 float TimeNum = 0;//扇形的繪軌制數 float AXLeft = 0;//設置餅形圖的X坐標 float AYUp = 0;//設置餅形圖的Y坐標 float AXSize = 0;//設置餅形圖的寬度 float AYSize = 0;//設置餅形圖的高度 float Atop = 0;//記載餅形的高度為長和寬的最小值 float Aleft = 0;//記載餅形的高度為長和寬的最小值 Graphics TitG = panel1.CreateGraphics();//創立Graphics類對象 SizeF XMaxSize = TitG.MeasureString("", LSfont);//將繪制的字符串停止格局化 float SWidth = 0;//獲得字符串的寬度 float SHeight = 0;//獲得字符串的高度 //盤算餅形圖的初始地位 XLeft = panel1.Width - (panel1.Width - 5);//去了邊框後餅形圖的X地位 XSize = panel1.Width - 10;//設置餅形圖的寬度 temXLeft = AXLeft;//記載餅形圖的X坐標 AXLeft = XLeft;//記載餅形圖的X坐標 AXSize = XSize;//記載餅形圖的寬度 //經由過程解釋文字的年夜小盤算餅形圖的地位 AXLeft = AXLeft + AreaXMaxWidth + Aline;//設置去除解釋文字後的餅形圖X坐標 AYUp = AYUp + AreaXMaxHeight;//設置去除解釋文字後的餅形圖Y坐標 AXSize = XSize - AreaXMaxWidth * 2 - Aline * 2;//設置去除解釋文字後的餅形圖寬度 AYSize = YSize - AreaXMaxHeight * 2;//設置去除解釋文字後的餅形圖高度 if (AXSize >= AYSize)//假如餅形圖的寬度年夜於等於高度 { Aleft = AXSize - AYSize;//記載餅形圖的X坐標 AXSize = AYSize;//將高度設為寬度 } else { Atop = AYSize - AXSize;//記載餅形圖的Y坐標 AYSize = AXSize;//將寬度設為高度 } if (Aleft != 0)//假如廣大於高 { AXLeft = AXLeft + Aleft / 2;//設置餅形圖橫向局中 } if (Atop != 0)//假如嵬峨於寬 { AYUp = AYUp + Atop / 2;//設置餅形圖縱向局中 } temXLeft = XLeft; //初始化解釋文字前橫線的變量 float X1 = 0; float Y1 = 0; float X2 = 0; float Y2 = 0; //初始化解釋文字地位的變量 float TX1 = 0; float TY1 = 0; float TX2 = 0; float TY2 = 0; float temf = 0;//記載百分比 double radians = 0;//記載扇形的角度 temf = (this.AreaAngle * (ASum / 360) / ASum);//記載肇端地位的度數 TimeNum = this.AreaAngle;//記載扇形的肇端角度 //繪制解釋文字 if (AXSize > 0 && AYSize > 0) { for (int i = 0; i < SzData.Length; i++)//遍歷一切解釋文字 { f = SzData[i] / ASum;//獲得以後記載的百分比 if (f == 0)//假如以後值為0 continue;//履行下一次輪回 radians = ((double)((temf + f / 2) * 360) * Math.PI) / (double)180; X1 = Convert.ToSingle(AXLeft + (AXSize / 2.0 + (int)((float)(AXSize / 2.0) * Math.Cos(radians)))); Y1 = Convert.ToSingle(AYUp + (AYSize / 2.0 + (int)((float)(AYSize / 2.0) * Math.Sin(radians)))); XMaxSize = TitG.MeasureString(AreaText[i].Trim(), LSfont);//將繪制的字符串停止格局化 SWidth = XMaxSize.Width;//獲得字符串的寬度 SHeight = XMaxSize.Height;//獲得字符串的高度 if ((temf + f / 2) * 360 > 90 && (temf + f / 2) * 360 <= 270) { X2 = X1 - Aline; TX1 = X2 - 1 - SWidth; TY1 = Y1 - SHeight / 2 - Asash; TX2 = SWidth; TY2 = SHeight + Asash * 2; g.FillRectangle(ATbrush, TX1, TY1, TX2, TY2);//繪制內矩形 g.DrawRectangle(new Pen(Color.Black, 1), TX1, TY1, TX2, TY2);//繪制矩形 g.DrawString(AreaText[i].Trim(), LSfont, Zbrush, new PointF(X2 - SWidth + Asash - 1, Y1 - SHeight / 2)); } else { X2 = X1 + Aline; TX1 = X2 + 1; TY1 = Y1 - SHeight / 2 - Asash; TX2 = SWidth; TY2 = SHeight + Asash * 2; g.FillRectangle(ATbrush, TX1, TY1, TX2, TY2);//繪制內矩形 g.DrawRectangle(new Pen(Color.Black, 1), TX1, TY1, TX2, TY2);//繪制矩形 g.DrawString(AreaText[i].Trim(), LSfont, Zbrush, new PointF(X2 + Asash + 1, Y1 - SHeight / 2)); } Y2 = Y1; g.DrawLine(new Pen(new SolidBrush(Color.Black), 1), X1, Y1, X2, Y2); TimeNum += f * 360; temf = temf + f; } } else return; } #endregion private void panel1_Paint(object sender, PaintEventArgs e) { XSize = panel1.Width;//X軸的年夜小 YSize = panel1.Height;//Y軸的年夜小 YDown = panel1.Height;//Y軸的下端點 ProtractArea(e.Graphics); } private void Form1_Load(object sender, EventArgs e) { } } }
本例附有具體的正文解釋,信任不難懂得,讀者還可以對其停止功效的修正或擴大,以完成更豐碩的圖文表示情勢。