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)
{
}
}
}
本例附有具體的正文解釋,信任不難懂得,讀者還可以對其停止功效的修正或擴大,以完成更豐碩的圖文表示情勢。