C#利用折线图分析产品销售走势
2022/7/17 1:15:03
本文主要是介绍C#利用折线图分析产品销售走势,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
图形界面
数据
查询效果
代码
private void button1_Click(object sender, EventArgs e) { G++; DrowFont(this.comboBox1.Text.ToString()); DrowInfo(this.comboBox1.Text.ToString()); DrowPic(this.comboBox1.Text.ToString()); }
private void DrowFont(string str) { using(Graphics GrapFont = this.panel1.CreateGraphics()) { GrapFont.Clear(Color.SeaShell); Pen p = new Pen(Color.Blue, 2.0f); Font f = new Font("华文新魏", 12, FontStyle.Regular); Brush b = new SolidBrush(Color.Blue); GrapFont.DrawString("『" + str + "』"+"产品销售走势", f, b, 4.0f, 5.0f); } } private void DrowInfo(string str) { Graphics g = this.groupBox2.CreateGraphics(); //创建Graphics对象 g.Clear(Color.SeaShell); //设置背景颜色 Brush b = new SolidBrush(Color.Blue); //创建Brush对象 Font f = new Font("Arial", 9, FontStyle.Regular); //设置Font对象 using (sqlAda = new SqlDataAdapter("select * from tb_merchandise where t_name='" + str + "' order by t_date", con)) { DataSet ds = new DataSet(); //创建DataSet对象 sqlAda.Fill(ds, "tb_09"); //Fill方法填充对象 g.DrawString("月份: " + "价格", f, b, 10.0f, 25.0f); //绘制标题 for (int i = 0; i < ds.Tables[0].Rows.Count; i++) //绘制月份及相应的产品价格 { int month = Convert.ToDateTime(ds.Tables[0].Rows[i][2].ToString()).Month;//获取月份 if (month >= 10) { //绘制月份及价格 g.DrawString(month + "月: " + "『" + ds.Tables[0].Rows[i][3].ToString() + " 』", f, b, 10.0f, (i + 2) * 25.0f); } else { g.DrawString("0" + month + "月: " + "『" + ds.Tables[0].Rows[i][3].ToString() + " 』", f, b, 10.0f, (i + 2) * 25.0f); } } } }
private void DrowPic(string str) { int MaxValue, MinValue; //声明变量记录最大值和最小值 using (cmd = new SqlCommand("select Max(t_price) from tb_merchandise where t_name='" + str + "'", con)) { con.Open(); //打开数据库连接 MaxValue = Convert.ToInt16(cmd.ExecuteScalar()); //获取最大值 con.Close(); //关闭数据库连接 } using (cmd = new SqlCommand("select Min(t_price) from tb_merchandise where t_name='" + str + "'", con)) { con.Open(); //打开数据库连接 MinValue = Convert.ToInt16(cmd.ExecuteScalar()); //获取最小值 con.Close(); //关闭数据库连接 } Graphics g = this.groupBox1.CreateGraphics(); //创建Graphics对象 g.Clear(Color.SeaShell); //设置背景 Brush b = new SolidBrush(Color.Blue); //创建Brush对象 Font f = new Font("Arial", 9, FontStyle.Regular); //创建Font对象 Pen p = new Pen(b); //创建Pen对象 using (sqlAda = new SqlDataAdapter("select * from tb_merchandise where t_name='" + str + "' order by t_date", con)) { ds = new DataSet(); //实例化DataSet对象 sqlAda.Fill(ds, "t_date"); //Fill方法填充对象 int M = MaxValue / 50 + 1; //最大值 int N = MinValue / 50; //最小值 int T = N; for (int i = 0; i <= M - N; i++) { g.DrawString(Convert.ToString(T * 50), f, b, 0, 190 - 30 * i); g.DrawLine(p, 30, 200 - 30 * i, 260, 200 - 30 * i); T++; } int Num = ds.Tables[0].Rows.Count; int[] Values = new int[Num]; for (int C = 0; C < Num; C++) { Values[C] = Convert.ToInt32(ds.Tables[0].Rows[C][3].ToString()); g.DrawString(Convert.ToDateTime(ds.Tables[0].Rows[C][2].ToString()).Month + "月", f, b, 30 * (C + 1) - 10, 15); g.DrawLine(p, 30 * (C + 1), 200, 30 * (C + 1), 30); } Point[] P = new Point[Num]; for (int i = 0; i < Num; i++) { P[i].X = 30 * (i + 1); P[i].Y = 290 - Convert.ToInt32(Values[i] / 50f * 30); } g.DrawLines(p, P); } }
这篇关于C#利用折线图分析产品销售走势的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2022-03-01沐雪多租宝商城源码从.NetCore3.1升级到.Net6的步骤
- 2024-12-06使用Microsoft.Extensions.AI在.NET中生成嵌入向量
- 2024-11-18微软研究:RAG系统的四个层次提升理解与回答能力
- 2024-11-15C#中怎么从PEM格式的证书中提取公钥?-icode9专业技术文章分享
- 2024-11-14云架构设计——如何用diagrams.net绘制专业的AWS架构图?
- 2024-05-08首个适配Visual Studio平台的国产智能编程助手CodeGeeX正式上线!C#程序员必备效率神器!
- 2024-03-30C#设计模式之十六迭代器模式(Iterator Pattern)【行为型】
- 2024-03-29c# datetime tryparse
- 2024-02-21list find index c#
- 2024-01-24convert toint32 c#