基本信息
源码名称:利用饼型图分析产品市场占有率 实例 附源码
源码大小:0.05M
文件格式:.zip
开发语言:C#
更新时间:2013-05-13
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍



    public partial class Frm_Main : Form
    {
        static int SumNum;
        static float TimeNum;
        SqlConnection con;
        SqlCommand cmd;
        Hashtable ht = new Hashtable();
        public Frm_Main()
        {
            InitializeComponent();
        }
        private void Conn()
        {
            con = new SqlConnection("server=WRET-MOSY688YVW\\MRGLL;UID=sa;Pwd=hbyt2008!@#;database=db_TomeOne");
            con.Open();
        }

        private void showPic(float f, Brush B)
        {
            Graphics g = this.panel1.CreateGraphics();					//通过panel1控件创建一个Graphics对象
            if (TimeNum == 0.0f)
            {
                g.FillPie(B, 0, 0, this.panel1.Width, this.panel1.Height, 0, f * 360);//绘制扇形
            }
            else
            {
                g.FillPie(B, 0, 0, this.panel1.Width, this.panel1.Height, TimeNum, f * 360);
            }
            TimeNum  = f * 360;
        }
        private void Form1_Paint(object sender, PaintEventArgs e)			//在Paint事件中绘制窗体
        {
            ht.Clear();
            Conn();											//连接数据库
            Random rnd = new Random();								//生成随机数
            using (cmd = new SqlCommand("select t_Name,sum(t_Num) as Num  from tb_product group by t_Name", con))
            {
                Graphics g2 = this.panel2.CreateGraphics();				//通过panel2控件创建一个Graphics对象
                SqlDataReader dr = cmd.ExecuteReader();					//创建SqlDataReader对象
                while (dr.Read())									//读取数据
                {
                    ht.Add(dr[0], Convert.ToInt32(dr[1]));					//将数据添加到Hashtable中
                }
                float[] flo = new float[ht.Count];
                int T = 0;
                foreach (DictionaryEntry de in ht)						//遍历Hashtable
                {
                    flo[T] = Convert.ToSingle((Convert.ToDouble(de.Value) / SumNum).ToString().Substring(0, 6));
                    Brush Bru = new SolidBrush(Color.FromArgb(rnd.Next(255), rnd.Next(255), rnd.Next(255)));
                    //绘制商品及百分比
                    g2.DrawString(de.Key   "  "   flo[T] * 100   "%", new Font("Arial", 8, FontStyle.Regular), Bru, 7, 5   T * 18);
                    showPic(flo[T], Bru);							//调用showPic方法绘制饼型图
                    T  ;
                }
            }
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            Conn();
            using (cmd = new SqlCommand("select Sum(t_Num)  from tb_product", con))
            {
               SumNum=Convert.ToInt32(cmd.ExecuteScalar());
            }
        }
    }