C# 繪製統計圖(柱狀圖, 折線圖, 扇形圖)

C# 繪製統計圖(柱狀圖, 折線圖, 扇形圖)

統計圖形種類繁多, 有柱狀圖, 折線圖, 扇形圖等等, 而統計圖形的繪製方法也有不少, 有Flash製做的統計圖形, 有水晶 報表生成統計圖形, 有專門製圖軟件製做, 也有編程 語言本身製做的;這裏咱們用就C# 製做三款最經典的統計圖: 柱狀圖, 折線圖和扇形圖;既然是統計, 固然須要數據, 這裏演示的數據存於Sql Server2000中, 三款統計圖形都是動態生成. 其中柱狀圖我會附上製做步驟, 其餘兩款統計圖直接附源碼.



說明: 需求不同, 統計圖形繪製後的顯示效果也不同, 好比這裏柱狀圖的主要需求是爲了比較每一期報名人數與經過人數的差, 所以會把兩根柱子放在一塊兒會使比較結果一目瞭然. 所以你們能夠根據須要靈活繪製.

 

一. 柱狀圖的繪製.

繪製步驟以下:

1. 定義繪圖用到的類.

定義繪圖類
  1. int height = 500, width = 700;
  2. Bitmap image = new Bitmap(width, height);
  3. Graphics g = Graphics.FromImage(image);
  4. Pen mypen = new Pen(brush, 1);
複製代碼
2. 繪製圖框.

繪製圖框
  1. g.FillRectangle(Brushes.WhiteSmoke, 0, 0, width, height);
複製代碼
3. 繪製橫向座標線

繪製橫向座標線
  1. for (int i = 0; i < 14; i++)
  2. {
  3. g.DrawLine(mypen, x, 80, x, 340);
  4. x = x + 40;
  5. }
複製代碼
4. 繪製縱向座標線

繪製縱向座標線
  1. for (int i = 0; i < 9; i++)
  2. {
  3. g.DrawLine(mypen, 60, y, 620, y);
  4. y = y + 26;
  5. }
複製代碼
5. 繪製橫座標值

繪製橫座標值
  1. String[] n = { "第一期", "第二期", "第三期", "第四期", "整年" };
  2. for (int i = 0; i < 7; i++)
  3. {
  4. g.DrawString(n.ToString(), font, Brushes.Blue, x, 348);
  5. x = x + 78;
  6. }
複製代碼
6. 繪製縱座標值

繪製縱座標
  1. String[] m = {"250","225", "200", "175", "150", "125", "100「};
  2. for (int i = 0; i < 10; i++)
  3. {
  4. g.DrawString(m.ToString(), font, Brushes.Blue, 25, y);
  5. y = y + 26;
  6. }
複製代碼
7. 定義數組 存儲數據庫中統計的數據

定義存儲統計數據的數組
  1. int[] Count1 = new int[7]; //存儲從數據庫讀取的報名人數
  2. int[] Count2 = new int[7]; //存儲從數據庫讀取的經過人數
複製代碼
8. 從數據庫中讀取報名人數與經過人數

讀取數據
  1. SqlConnection Con = new SqlConnection(
  2. "Server=(Local);Database=committeeTraining;");
  3. Con.Open();
  4. string cmdtxt2 = "SELECT * FROM ##Count
  5. where Company='" + ****+ "'";
  6. SqlDataAdapter da = new SqlDataAdapter(cmdtxt2, Con);
  7. DataSet ds = new DataSet();
  8. da.Fill(ds);
複製代碼
9. 將讀取的數據存儲到數組中

將數據存儲到數組中
  1. Count1[0] = Convert.ToInt32(ds.Tables[0].Rows[0][「count1」].ToString());
  2. Count1[1] = Convert.ToInt32(ds.Tables[0].Rows[0][「count3」].ToString());
  3. Count2[0] = Convert.ToInt32(ds.Tables[0].Rows[0][「count2」].ToString());
  4. Count2[1] = Convert.ToInt32(ds.Tables[0].Rows[0]["count4"].ToString());
複製代碼
10.定義畫筆和畫刷準備繪圖

準備繪製柱狀圖
  1. x = 80;
  2. Font font2 = new System.Drawing.Font(
  3. "Arial", 10, FontStyle.Bold);
  4. SolidBrush mybrush = new SolidBrush(Color.Red);
  5. SolidBrush mybrush2 = new SolidBrush(Color.Green);
複製代碼
11. 根據數組中的值繪製柱狀圖



繪製柱狀圖

(1)第一期報名人數
  1. g.FillRectangle(mybrush, x, 340 - Count1[0], 20, Count1[0]);
  2. g.DrawString(Count1[0].ToString(), font2,
  3. Brushes.Red, x, 340 - Count1[0] - 15);
複製代碼
(2) 第一期經過人數
  1. x = x + 20;
  2. g.FillRectangle(mybrush2, x, 340 - Count2[0], 20, Count2[0]);
  3. g.DrawString(Count2[0].ToString(), font2,
  4. Brushes.Green, x, 340 - Count2[0] - 15);
複製代碼
12. 將圖形輸出到頁面.

將頁面輸出到頁中
  1. System.IO.MemoryStream ms = new
  2. System.IO.MemoryStream();
  3. image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);
  4. Response.ClearContent();
  5. Response.ContentType = "image/Jpeg";
  6. Response.BinaryWrite(ms.ToArray());
複製代碼
最終柱狀圖的效果圖:

附件: histogram.png



柱狀圖的完整代碼:

繪製柱狀統計圖的完整代碼
  1. private void CreateImage()
  2. {
  3. int height = 500, width = 700;
  4. Bitmap image = new Bitmap(width, height);
  5. //建立Graphics類對象
  6. Graphics g = Graphics.FromImage(image);

  7. try
  8. {
  9. //清空圖片背景色
  10. g.Clear(Color.White);

  11. Font font = new Font("Arial", 10, FontStyle.Regular);
  12. Font font1 = new Font("宋體", 20, FontStyle.Bold);

  13. LinearGradientBrush brush = new LinearGradientBrush(new Rectangle(0, 0, image.Width, image.Height),
  14. Color.Blue, Color.BlueViolet, 1.2f, true);
  15. g.FillRectangle(Brushes.WhiteSmoke, 0, 0, width, height);
  16. // Brush brush1 = new SolidBrush(Color.Blue);

  17. g.DrawString(this.ddlTaget.SelectedItem.Text + " " + this.ddlYear.SelectedItem.Text +
  18. " 成績統計柱狀圖", font1, brush, new PointF(70, 30));
  19. //畫圖片的邊框線
  20. g.DrawRectangle(new Pen(Color.Blue), 0, 0, image.Width - 1, image.Height - 1);


  21. Pen mypen = new Pen(brush, 1);
  22. //繪製線條
  23. //繪製橫向線條
  24. int x = 100;
  25. for (int i = 0; i < 14; i++)
  26. {
  27. g.DrawLine(mypen, x, 80, x, 340);
  28. x = x + 40;
  29. }
  30. Pen mypen1 = new Pen(Color.Blue, 2);
  31. x = 60;
  32. g.DrawLine(mypen1, x, 80, x, 340);

  33. //繪製縱向線條
  34. int y = 106;
  35. for (int i = 0; i < 9; i++)
  36. {
  37. g.DrawLine(mypen, 60, y, 620, y);
  38. y = y + 26;
  39. }
  40. g.DrawLine(mypen1, 60, y, 620, y);

  41. //x軸
  42. String[] n = { "第一期", "第二期", "第三期", "第四期", "上半年", "下半年", "整年統計" };
  43. x = 78;
  44. for (int i = 0; i < 7; i++)
  45. {
  46. g.DrawString(n.ToString(), font, Brushes.Blue, x, 348); //設置文字內容及輸出位置
  47. x = x + 78;
  48. }

  49. //y軸
  50. String[] m = {"250","225", "200", "175", "150", "125", "100", " 75",
  51. " 50", " 25", " 0"};
  52. y = 72;
  53. for (int i = 0; i < 10; i++)
  54. {
  55. g.DrawString(m.ToString(), font, Brushes.Blue, 25, y); //設置文字內容及輸出位置
  56. y = y + 26;
  57. }

  58. int[] Count1 = new int[7];
  59. int[] Count2 = new int[7];

  60. SqlConnection Con = new SqlConnection("Server=(Local);Database=committeeTraining;Uid=sa;Pwd=**");
  61. Con.Open();
  62. string cmdtxt2 = "SELECT * FROM ##Count where Company='" + this.ddlTaget.SelectedItem.Text.Trim() + "'";
  63. SqlDataAdapter da = new SqlDataAdapter(cmdtxt2, Con);
  64. DataSet ds = new DataSet();
  65. da.Fill(ds);

  66. Count1[0] = Convert.ToInt32(ds.Tables[0].Rows[0]["count1"].ToString());
  67. Count1[1] = Convert.ToInt32(ds.Tables[0].Rows[0]["count3"].ToString());
  68. Count1[2] = Convert.ToInt32(ds.Tables[0].Rows[0]["count5"].ToString());
  69. Count1[3] = Convert.ToInt32(ds.Tables[0].Rows[0]["count7"].ToString());

  70. Count1[4] = Count1[0] + Count1[1];
  71. Count1[5] = Count1[2] + Count1[3];

  72. Count1[6] = Convert.ToInt32(ds.Tables[0].Rows[0]["count9"].ToString());


  73. Count2[0] = Convert.ToInt32(ds.Tables[0].Rows[0]["count2"].ToString());
  74. Count2[1] = Convert.ToInt32(ds.Tables[0].Rows[0]["count4"].ToString());
  75. Count2[2] = Convert.ToInt32(ds.Tables[0].Rows[0]["count6"].ToString());
  76. Count2[3] = Convert.ToInt32(ds.Tables[0].Rows[0]["count8"].ToString());

  77. Count2[4] = Count2[0] + Count2[1];
  78. Count2[5] = Count2[2] + Count2[3];

  79. Count2[6] = Convert.ToInt32(ds.Tables[0].Rows[0]["count10"].ToString());

  80. //繪製柱狀圖.
  81. x = 80;
  82. Font font2 = new System.Drawing.Font("Arial", 10, FontStyle.Bold);
  83. SolidBrush mybrush = new SolidBrush(Color.Red);
  84. SolidBrush mybrush2 = new SolidBrush(Color.Green);

  85. //第一期
  86. g.FillRectangle(mybrush, x, 340 - Count1[0], 20, Count1[0]);
  87. g.DrawString(Count1[0].ToString(), font2, Brushes.Red, x, 340 - Count1[0] - 15);

  88. x = x + 20;
  89. g.FillRectangle(mybrush2, x, 340 - Count2[0], 20, Count2[0]);
  90. g.DrawString(Count2[0].ToString(), font2, Brushes.Green, x, 340 - Count2[0] - 15);


  91. //第二期
  92. x = x + 60;
  93. g.FillRectangle(mybrush, x, 340 - Count1[1], 20, Count1[1]);
  94. g.DrawString(Count1[1].ToString(), font2, Brushes.Red, x, 340 - Count1[1] - 15);


  95. x = x + 20;
  96. g.FillRectangle(mybrush2, x, 340 - Count2[1], 20, Count2[1]);
  97. g.DrawString(Count2[1].ToString(), font2, Brushes.Green, x, 340 - Count2[1] - 15);


  98. //第三期
  99. x = x + 60;
  100. g.FillRectangle(mybrush, x, 340 - Count1[2], 20, Count1[2]);
  101. g.DrawString(Count1[2].ToString(), font2, Brushes.Red, x, 340 - Count1[2] - 15);

  102. x = x + 20;
  103. g.FillRectangle(mybrush2, x, 340 - Count2[2], 20, Count2[2]);
  104. g.DrawString(Count2[2].ToString(), font2, Brushes.Green, x, 340 - Count2[2] - 15);

  105. //第四期
  106. x = x + 60;
  107. g.FillRectangle(mybrush, x, 340 - Count1[3], 20, Count1[3]);
  108. g.DrawString(Count1[3].ToString(), font2, Brushes.Red, x, 340 - Count1[3] - 15);

  109. x = x + 20;
  110. g.FillRectangle(mybrush2, x, 340 - Count2[3], 20, Count2[3]);
  111. g.DrawString(Count2[3].ToString(), font2, Brushes.Green, x, 340 - Count2[3] - 15);

  112. //上半年
  113. x = x + 60;
  114. g.FillRectangle(mybrush, x, 340 - Count1[4], 20, Count1[4]);
  115. g.DrawString(Count1[4].ToString(), font2, Brushes.Red, x, 340 - Count1[4] - 15);

  116. x = x + 20;
  117. g.FillRectangle(mybrush2, x, 340 - Count2[4], 20, Count2[4]);
  118. g.DrawString(Count2[4].ToString(), font2, Brushes.Green, x, 340 - Count2[4] - 15);

  119. //下半年
  120. x = x + 60;
  121. g.FillRectangle(mybrush, x, 340 - Count1[5], 20, Count1[5]);
  122. g.DrawString(Count1[5].ToString(), font2, Brushes.Red, x, 340 - Count1[5] - 15);

  123. x = x + 20;
  124. g.FillRectangle(mybrush2, x, 340 - Count2[5], 20, Count2[5]);
  125. g.DrawString(Count2[5].ToString(), font2, Brushes.Green, x, 340 - Count2[5] - 15);

  126. //整年
  127. x = x + 60;
  128. g.FillRectangle(mybrush, x, 340 - Count1[6], 20, Count1[6]);
  129. g.DrawString(Count1[6].ToString(), font2, Brushes.Red, x, 340 - Count1[6] - 15);


  130. x = x + 20;
  131. g.FillRectangle(mybrush2, x, 340 - Count2[6], 20, Count2[6]);
  132. g.DrawString(Count2[6].ToString(), font2, Brushes.Green, x, 340 - Count2[6] - 15);


  133. //繪製標識
  134. Font font3 = new System.Drawing.Font("Arial", 10, FontStyle.Regular);
  135. g.DrawRectangle(new Pen(Brushes.Blue), 170, 400, 250, 50); //繪製範圍框
  136. g.FillRectangle(Brushes.Red, 270, 410, 20, 10); //繪製小矩形
  137. g.DrawString("報名人數", font3, Brushes.Red, 292, 408);

  138. g.FillRectangle(Brushes.Green, 270, 430, 20, 10);
  139. g.DrawString("經過人數", font3, Brushes.Green, 292, 428);

  140. System.IO.MemoryStream ms = new System.IO.MemoryStream();
  141. image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);
  142. Response.ClearContent();
  143. Response.ContentType = "image/Jpeg";
  144. Response.BinaryWrite(ms.ToArray());
  145. }
  146. finally
  147. {
  148. g.Dispose();
  149. image.Dispose();
  150. }
  151. }
複製代碼
二. 折線統計圖的繪製

效果:

附件: line chart.png


折線圖的完整代碼:

折線圖的完整代碼
  1. private void CreateImage()
  2. {
  3. int height = 480, width = 700;
  4. Bitmap image = new Bitmap(width, height);
  5. Graphics g = Graphics.FromImage(image);

  6. try
  7. {
  8. //清空圖片背景色
  9. g.Clear(Color.White);

  10. Font font = new System.Drawing.Font("Arial", 9, FontStyle.Regular);
  11. Font font1 = new System.Drawing.Font("宋體", 20, FontStyle.Regular);
  12. Font font2 = new System.Drawing.Font("Arial", 8, FontStyle.Regular);
  13. LinearGradientBrush brush = new LinearGradientBrush(
  14. new Rectangle(0, 0, image.Width, image.Height), Color.Blue, Color.Blue, 1.2f, true);
  15. g.FillRectangle(Brushes.AliceBlue, 0, 0, width, height);
  16. Brush brush1 = new SolidBrush(Color.Blue);
  17. Brush brush2 = new SolidBrush(Color.SaddleBrown);

  18. g.DrawString(this.ddlTaget.SelectedItem.Text + " " + this.ddlYear.SelectedItem.Text +
  19. " 成績統計折線圖", font1, brush1, new PointF(85, 30));
  20. //畫圖片的邊框線
  21. g.DrawRectangle(new Pen(Color.Blue), 0, 0, image.Width - 1, image.Height - 1);

  22. Pen mypen = new Pen(brush, 1);
  23. Pen mypen2 = new Pen(Color.Red, 2);
  24. //繪製線條
  25. //繪製縱向線條
  26. int x = 60;
  27. for (int i = 0; i < 8; i++)
  28. {
  29. g.DrawLine(mypen, x, 80, x, 340);
  30. x = x + 80;
  31. }
  32. Pen mypen1 = new Pen(Color.Blue, 3);
  33. x = 60;
  34. g.DrawLine(mypen1, x, 82, x, 340);

  35. //繪製橫向線條
  36. int y = 106;
  37. for (int i = 0; i < 10; i++)
  38. {
  39. g.DrawLine(mypen, 60, y, 620, y);
  40. y = y + 26;
  41. }
  42. // y = 106;
  43. g.DrawLine(mypen1, 60, y - 26, 620, y - 26);

  44. //x軸
  45. String[] n = { "第一期", "第二期", "第三期", "第四期", "上半年", "下半年", "整年統計" };
  46. x = 45;
  47. for (int i = 0; i < 7; i++)
  48. {
  49. g.DrawString(n.ToString(), font, Brushes.Red, x, 348); //設置文字內容及輸出位置
  50. x = x + 77;
  51. }

  52. //y軸
  53. String[] m = { "220人", " 200人", " 175人", "150人", " 125人", " 100人", " 75人", " 50人",
  54. " 25人"};
  55. y = 100;
  56. for (int i = 0; i < 9; i++)
  57. {
  58. g.DrawString(m.ToString(), font, Brushes.Red, 10, y); //設置文字內容及輸出位置
  59. y = y + 26;
  60. }

  61. int[] Count1 = new int[7];
  62. int[] Count2 = new int[7];

  63. SqlConnection Con = new SqlConnection("Server=(Local);Database=committeeTraining;Uid=sa;Pwd=eesoft");
  64. Con.Open();
  65. string cmdtxt2 = "SELECT * FROM ##Count where Company='" + this.ddlTaget.SelectedItem.Text.Trim() + "'";
  66. SqlDataAdapter da = new SqlDataAdapter(cmdtxt2, Con);
  67. DataSet ds = new DataSet();
  68. da.Fill(ds);

  69. //報名人數
  70. Count1[0] = Convert.ToInt32(ds.Tables[0].Rows[0]["count1"].ToString());
  71. Count1[1] = Convert.ToInt32(ds.Tables[0].Rows[0]["count3"].ToString());
  72. Count1[2] = Convert.ToInt32(ds.Tables[0].Rows[0]["count5"].ToString());
  73. Count1[3] = Convert.ToInt32(ds.Tables[0].Rows[0]["count7"].ToString());

  74. Count1[6] = Convert.ToInt32(ds.Tables[0].Rows[0]["count9"].ToString()); //整年

  75. Count1[4] = Count1[0] + Count1[1];
  76. Count1[5] = Count1[2] + Count1[3];


  77. Count2[0] = Convert.ToInt32(ds.Tables[0].Rows[0]["count2"].ToString());
  78. Count2[1] = Convert.ToInt32(ds.Tables[0].Rows[0]["count4"].ToString());
  79. Count2[2] = Convert.ToInt32(ds.Tables[0].Rows[0]["count6"].ToString());
  80. Count2[3] = Convert.ToInt32(ds.Tables[0].Rows[0]["count8"].ToString());

  81. Count2[6] = Convert.ToInt32(ds.Tables[0].Rows[0]["count10"].ToString()); //整年

  82. Count2[4] = Count2[0] + Count2[1];
  83. Count2[5] = Count2[2] + Count2[3];


  84. //顯示折線效果
  85. Font font3 = new System.Drawing.Font("Arial", 10, FontStyle.Bold);
  86. SolidBrush mybrush = new SolidBrush(Color.Red);
  87. Point[] points1 = new Point[7];
  88. points1[0].X = 60; points1[0].Y = 340 - Count1[0]; //從106縱座標開始, 到(0, 0)座標時
  89. points1[1].X = 140; points1[1].Y = 340 - Count1[1];
  90. points1[2].X = 220; points1[2].Y = 340 - Count1[2];
  91. points1[3].X = 300; points1[3].Y = 340 - Count1[3];

  92. points1[4].X = 380; points1[4].Y = 340 - Count1[4];
  93. points1[5].X = 460; points1[5].Y = 340 - Count1[5];

  94. points1[6].X = 540; points1[6].Y = 340 - Count1[6];
  95. g.DrawLines(mypen2, points1); //繪製折線

  96. //繪製數字
  97. g.DrawString(Count1[0].ToString(), font3, Brushes.Red, 58, points1[0].Y - 20);
  98. g.DrawString(Count1[1].ToString(), font3, Brushes.Red, 138, points1[1].Y - 20);
  99. g.DrawString(Count1[2].ToString(), font3, Brushes.Red, 218, points1[2].Y - 20);
  100. g.DrawString(Count1[3].ToString(), font3, Brushes.Red, 298, points1[3].Y - 20);

  101. g.DrawString(Count1[4].ToString(), font3, Brushes.Red, 378, points1[4].Y - 20);
  102. g.DrawString(Count1[5].ToString(), font3, Brushes.Red, 458, points1[5].Y - 20);

  103. g.DrawString(Count1[6].ToString(), font3, Brushes.Red, 538, points1[6].Y - 20);

  104. Pen mypen3 = new Pen(Color.Green, 2);
  105. Point[] points2 = new Point[7];
  106. points2[0].X = 60; points2[0].Y = 340 - Count2[0];
  107. points2[1].X = 140; points2[1].Y = 340 - Count2[1];
  108. points2[2].X = 220; points2[2].Y = 340 - Count2[2];
  109. points2[3].X = 300; points2[3].Y = 340 - Count2[3];

  110. points2[4].X = 380; points2[4].Y = 340 - Count2[4];
  111. points2[5].X = 460; points2[5].Y = 340 - Count2[5];

  112. points2[6].X = 540; points2[6].Y = 340 - Count2[6];
  113. g.DrawLines(mypen3, points2); //繪製折線

  114. //繪製經過人數
  115. g.DrawString(Count2[0].ToString(), font3, Brushes.Green, 61, points2[0].Y - 15);
  116. g.DrawString(Count2[1].ToString(), font3, Brushes.Green, 131, points2[1].Y - 15);
  117. g.DrawString(Count2[2].ToString(), font3, Brushes.Green, 221, points2[2].Y - 15);
  118. g.DrawString(Count2[3].ToString(), font3, Brushes.Green, 301, points2[3].Y - 15);

  119. g.DrawString(Count2[4].ToString(), font3, Brushes.Green, 381, points2[4].Y - 15);
  120. g.DrawString(Count2[5].ToString(), font3, Brushes.Green, 461, points2[5].Y - 15);

  121. g.DrawString(Count2[6].ToString(), font3, Brushes.Green, 541, points2[6].Y - 15);

  122. //繪製標識
  123. g.DrawRectangle(new Pen(Brushes.Red), 180, 390, 250, 50); //繪製範圍框
  124. g.FillRectangle(Brushes.Red, 270, 402, 20, 10); //繪製小矩形
  125. g.DrawString("報名人數", font2, Brushes.Red, 292, 400);

  126. g.FillRectangle(Brushes.Green, 270, 422, 20, 10);
  127. g.DrawString("經過人數", font2, Brushes.Green, 292, 420);

  128. System.IO.MemoryStream ms = new System.IO.MemoryStream();
  129. image.Save(ms, System.Drawing.Imaging.ImageFormat.Jpeg);
  130. Response.ClearContent();
  131. Response.ContentType = "image/Jpeg";
  132. Response.BinaryWrite(ms.ToArray());
  133. }
  134. finally
  135. {
  136. g.Dispose();
  137. image.Dispose();
  138. }
  139. }
複製代碼
三. 扇形統計圖的繪製

效果圖:

附件: fan chart.gif





完整代碼:

扇形統計圖的繪製
  1. private void CreateImage()
  2. {
  3. //把鏈接字串指定爲一個常量
  4. SqlConnection Con = new SqlConnection("Server=(Local);
  5. Database=committeeTraining;Uid=sa;Pwd=**");
  6. Con.Open();
  7. string cmdtxt = selectString; // "select * from ##Count"; //
  8. //SqlCommand Com = new SqlCommand(cmdtxt, Con);
  9. DataSet ds = new DataSet();
  10. SqlDataAdapter Da = new SqlDataAdapter(cmdtxt, Con);
  11. Da.Fill(ds);
  12. Con.Close();
  13. float Total = 0.0f, Tmp;

  14. //轉換成單精度。也可寫成Convert.ToInt32
  15. Total = Convert.ToSingle(ds.Tables[0].Rows[0][this.count[0]]);

  16. // Total=Convert.ToSingle(ds.Tables[0].Rows[0][this.count[0]]);
  17. //設置字體,fonttitle爲主標題的字體
  18. Font fontlegend = new Font("verdana", 9);
  19. Font fonttitle = new Font("verdana", 10, FontStyle.Bold);

  20. //背景寬
  21. int width = 350;
  22. int bufferspace = 15;
  23. int legendheight = fontlegend.Height * 10 + bufferspace; //高度
  24. int titleheight = fonttitle.Height + bufferspace;
  25. int height = width + legendheight + titleheight + bufferspace;//白色背景高
  26. int pieheight = width;
  27. Rectangle pierect = new Rectangle(0, titleheight, width, pieheight);

  28. //加上各類隨機色
  29. ArrayList colors = new ArrayList();
  30. Random rnd = new Random();
  31. for (int i = 0; i < 2; i++)
  32. colors.Add(new SolidBrush(Color.FromArgb(rnd.Next(255), rnd.Next(255), rnd.Next(255))));

  33. //建立一個bitmap實例
  34. Bitmap objbitmap = new Bitmap(width, height);
  35. Graphics objgraphics = Graphics.FromImage(objbitmap);

  36. //畫一個白色背景
  37. objgraphics.FillRectangle(new SolidBrush(Color.White), 0, 0, width, height);

  38. //畫一個亮黃色背景
  39. objgraphics.FillRectangle(new SolidBrush(Color.Beige), pierect);

  40. //如下爲畫餅圖(有幾行row畫幾個)
  41. float currentdegree = 0.0f;

  42. //畫經過人數
  43. objgraphics.FillPie((SolidBrush)colors[1], pierect, currentdegree,
  44. Convert.ToSingle(ds.Tables[0].Rows[0][this.count[1]]) / Total * 360);
  45. currentdegree += Convert.ToSingle(ds.Tables[0].Rows[0][this.count[1]]) / Total * 360;

  46. //未經過人數餅狀圖
  47. objgraphics.FillPie((SolidBrush)colors[0], pierect, currentdegree,
  48. ((Convert.ToSingle(ds.Tables[0].Rows[0][this.count[0]]))-(Convert.ToSingle(ds.Tables[0].Rows[0][this.count[1]]))) / Total * 360);
  49. currentdegree += ((Convert.ToSingle(ds.Tables[0].Rows[0][this.count[0]])) -
  50. (Convert.ToSingle(ds.Tables[0].Rows[0][this.count[1]]))) / Total * 360;


  51. //如下爲生成主標題
  52. SolidBrush blackbrush = new SolidBrush(Color.Black);
  53. SolidBrush bluebrush = new SolidBrush(Color.Blue);
  54. string title = " 機關單位成績統計餅狀圖: "
  55. + "\n \n\n";
  56. StringFormat stringFormat = new StringFormat();
  57. stringFormat.Alignment = StringAlignment.Center;
  58. stringFormat.LineAlignment = StringAlignment.Center;

  59. objgraphics.DrawString(title, fonttitle, blackbrush,
  60. new Rectangle(0, 0, width, titleheight), stringFormat);

  61. //列出各字段與得數目
  62. objgraphics.DrawRectangle(new Pen(Color.Red, 2), 0, height + 10 - legendheight, width, legendheight + 50);

  63. objgraphics.DrawString("----------------統計信息------------------",
  64. fontlegend, bluebrush, 20, height - legendheight + fontlegend.Height * 1 + 1);
  65. objgraphics.DrawString("統計單位: " + this.ddlTaget.SelectedItem.Text,
  66. fontlegend, blackbrush, 20, height - legendheight + fontlegend.Height * 3 + 1);
  67. objgraphics.DrawString("統計年份: " + this.ddlYear.SelectedItem.Text,
  68. fontlegend, blackbrush, 20, height - legendheight + fontlegend.Height * 4 + 1);
  69. objgraphics.DrawString("統計期數: " + this.ddlSpan.SelectedItem.Text,
  70. fontlegend, blackbrush, 20, height - legendheight + fontlegend.Height * 5 + 1);

  71. objgraphics.FillRectangle((SolidBrush)colors[1], 5,height - legendheight + fontlegend.Height * 8 + 1, 10, 10);
  72. objgraphics.DrawString("報名總人數: " + Convert.ToString(Convert.ToSingle(ds.Tables[0].Rows[0][this.count[0]])),
  73. fontlegend, blackbrush, 20, height - legendheight + fontlegend.Height * 7 + 1);
  74. objgraphics.FillRectangle((SolidBrush)colors[0], 5, height - legendheight + fontlegend.Height * 9 + 1, 10, 10);
  75. objgraphics.DrawString("經過總人數: " + Convert.ToString(Convert.ToSingle(ds.Tables[0].Rows[0][this.count[1]])),
  76. fontlegend, blackbrush, 20, height - legendheight + fontlegend.Height * 8 + 1);
  77. objgraphics.DrawString("未經過人數: " + ((Convert.ToSingle(ds.Tables[0].Rows[0][this.count[0]])) -
  78. (Convert.ToSingle(ds.Tables[0].Rows[0][this.count[1]]))), fontlegend, blackbrush, 20, height - legendheight + fontlegend.Height * 9 + 1);

  79. objgraphics.DrawString("經過率: " + Convert.ToString((Convert.ToSingle(ds.Tables[0].Rows[0][this.count[1]]) /
  80. Convert.ToSingle(ds.Tables[0].Rows[0][this.count[0]])) * 100)+ " %", fontlegend,
  81. blackbrush, 20, height - legendheight + fontlegend.Height * 10 + 1);

  82. Response.ContentType = "image/Jpeg";
  83. objbitmap.Save(Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg);
  84. objgraphics.Dispose();
  85. objbitmap.Dispose();

  86. }
複製代碼
(文/ziyiFly  出處/博客園)

 

來自:http://www.pin5i.com/showtopic-20231.htmlhtml

posted on 2011-04-17 18:33  gisoracle  閱讀(443)  評論(0編輯  收藏  舉報 數據庫

相關文章
相關標籤/搜索