GDI 编程画折线&winform拖动圆点

//点击出现红点 

Point m_Pnt; 

 public Form1()
        {
            InitializeComponent();

            m_Pnt = new Point(-1, -1);
            pictureBox1.MouseClick += new MouseEventHandler(pictureBox1_MouseClick); 
            pictureBox1.Paint += new PaintEventHandler(pictureBox1_Paint);    
        }
         void pictureBox1_MouseClick(object sender, MouseEventArgs e)        
         {           
             // 这里模仿文本框修改坐标点,同时刷新下picturebox,鼠标点哪里,哪里就会画一个红点           
             m_Pnt = e.Location;            
             pictureBox1.Invalidate();        
         }        
        private void pictureBox1_Paint(object sender, PaintEventArgs e)        
        {            
            e.Graphics.FillEllipse( Brushes.Red, m_Pnt.X - 2, m_Pnt.Y - 2, 5, 5 );       
        }

//画x,y轴折线

 //数据初始化   
            string[] month = new string[12] { "一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月" };
            float[] d = new float[12] { 20.5F, 60, 10.8F, 15.6F, 30, 70.9F, 50.3F, 30.7F, 70, 50.4F, 30.8F, 20 };
            //画图初始化   
            Bitmap bMap = new Bitmap(500, 500);
            Graphics gph = Graphics.FromImage(bMap);
            gph.Clear(Color.White);


            PointF cPt = new PointF(40, 420);//原点  
          
            PointF[] xPt = new PointF[3]{
             new   PointF(cPt.Y+15,cPt.Y),
             new   PointF(cPt.Y,cPt.Y-8),
             new   PointF(cPt.Y,cPt.Y+8)};//X轴三角形   
            PointF[] yPt = new PointF[3]{
             new   PointF(cPt.X,cPt.X-15),
             new   PointF(cPt.X+8,cPt.X),
             new   PointF(cPt.X-8,cPt.X)};//Y轴三角形   
            gph.DrawString("某工厂某产品月生产量图表", new Font("宋体", 14),
             Brushes.Black, new PointF(cPt.X + 12, cPt.X));//图表标题   
            //画X轴   
            gph.DrawLine(Pens.Black, cPt.X, cPt.Y, cPt.Y, cPt.Y);
            gph.DrawPolygon(Pens.Black, xPt);
            gph.FillPolygon(new SolidBrush(Color.Black), xPt);
            gph.DrawString("月份", new Font("宋体", 12),
             Brushes.Black, new PointF(cPt.Y + 12, cPt.Y - 10));
            //画Y轴   
            gph.DrawLine(Pens.Black, cPt.X, cPt.Y, cPt.X, cPt.X);
            gph.DrawPolygon(Pens.Black, yPt);
            gph.FillPolygon(new SolidBrush(Color.Black), yPt);
            gph.DrawString("单位(万)", new Font("宋体", 12), Brushes.Black, new PointF(6, 7));
            for (int i = 1; i <= 12; i++)
            {
                //画Y轴刻度   
                if (i < 11)
                {
                    gph.DrawString((i * 10).ToString(), new Font("宋体", 11), Brushes.Black,
                     new PointF(cPt.X - 30, cPt.Y - i * 30 - 6));
                    gph.DrawLine(Pens.Red, cPt.X - 3, cPt.Y - i * 30, cPt.X, cPt.Y - i * 30);
                }
                //画X轴项目   
                gph.DrawString(month[i - 1].Substring(0, 1), new Font("宋体", 11), Brushes.Black,
                 new PointF(cPt.X + i * 30 - 5, cPt.Y + 5));
                gph.DrawString(month[i - 1].Substring(1, 1), new Font("宋体", 11),
                 Brushes.Black, new PointF(cPt.X + i * 30 - 5, cPt.Y + 20));
                if (month[i - 1].Length > 2)
                    gph.DrawString(month[i - 1].Substring(2, 1), new Font("宋体", 11),
                     Brushes.Black, new PointF(cPt.X + i * 30 - 5, cPt.Y + 35));
                //画点   
                gph.DrawEllipse(Pens.Black, cPt.X + i * 30 - 1.5F, cPt.Y - d[i - 1] * 3 - 1.5F, 3, 3);
                gph.FillEllipse(new SolidBrush(Color.Black), cPt.X + i * 30 - 1.5F, cPt.Y - d[i - 1] * 3 + 1.5F, 3, 3);
                //画数值   
                gph.DrawString(d[i - 1].ToString(), new Font("宋体", 11), Brushes.Black,
                 new PointF(cPt.X + i * 30, cPt.Y - d[i - 1] * 3));
                //画折线   
                if (i > 1)
                    gph.DrawLine(Pens.Red, cPt.X + (i - 1) * 30, cPt.Y - d[i - 2] * 3, cPt.X + i * 30, cPt.Y - d[i - 1] * 3);
            }
            //显示在pictureBox1控件中
            this.pictureBox1.Image = bMap;
            //保存输出图片   
           // bMap.Save("c:\\test.bmp");  

//winform拖动点

 public partial class Form1 : Form
    {
        Point p1, p2, p3, p4;
        Pen pb = new Pen(Color.Blue, 3);
        Pen pc = new Pen(Color.Red, 2);
        SolidBrush sb_on = new SolidBrush(Color.GreenYellow);
        SolidBrush sb_text = new SolidBrush(Color.Black);
        Font font;
        bool CanDrag;
        int index;
        float tol = 10;
        public Form1()
        {
            InitializeComponent();
            this.DoubleBuffered = true;
            this.Paint += new PaintEventHandler(Form1_Paint);
            this.MouseMove += new MouseEventHandler(Form1_MouseMove);
        }


        void Form1_MouseMove(object sender, MouseEventArgs e)
        {
            CanDrag = false;
            index = -1;
            Point p_mouse = e.Location;


            if (Math.Pow(p_mouse.X - p1.X, 2) + Math.Pow(p_mouse.Y - p1.Y, 2) <= tol * tol)
            {
                CanDrag = true;
                index = 1;
            }
            if (Math.Pow(p_mouse.X - p2.X, 2) + Math.Pow(p_mouse.Y - p2.Y, 2) <= tol * tol)
            {
                CanDrag = true;
                index = 2;
            }
            if (Math.Pow(p_mouse.X - p3.X, 2) + Math.Pow(p_mouse.Y - p3.Y, 2) <= tol * tol)
            {
                CanDrag = true;
                index = 3;
            }
            if (Math.Pow(p_mouse.X - p4.X, 2) + Math.Pow(p_mouse.Y - p4.Y, 2) <= tol * tol)
            {
                CanDrag = true;
                index = 4;
            }


            if (CanDrag && e.Button == MouseButtons.Left)
            {
                if (index == 1)
                    p1 = e.Location;
                if (index == 2)
                    p2 = e.Location;
                if (index == 3)
                    p3 = e.Location;
                if (index == 4)
                    p4 = e.Location;
            }
            this.Invalidate();
        }


        void Form1_Paint(object sender, PaintEventArgs e)
        {
            Graphics g = e.Graphics;
            g.SmoothingMode = SmoothingMode.AntiAlias;
            g.DrawBezier(pb, p1, p2, p3, p4);
            g.DrawLine(pc, p1, p2);
            g.DrawLine(pc, p3, p4);
            g.DrawString("P1", font, sb_text, p1);
            g.DrawString("P2", font, sb_text, p2);
            g.DrawString("P3", font, sb_text, p3);
            g.DrawString("P4", font, sb_text, p4);
            if (index == 1)
                g.FillEllipse(sb_on, new RectangleF(p1.X - tol / 2, p1.Y - tol / 2, tol, tol));
            if (index == 2)
                g.FillEllipse(sb_on, new RectangleF(p2.X - tol / 2, p2.Y - tol / 2, tol, tol));
            if (index == 3)
                g.FillEllipse(sb_on, new RectangleF(p3.X - tol / 2, p3.Y - tol / 2, tol, tol));
            if (index == 4)
                g.FillEllipse(sb_on, new RectangleF(p4.X - tol / 2, p4.Y - tol / 2, tol, tol));
        }


        private void Form1_Load(object sender, EventArgs e)
        {
            p1 = new Point(40, 40);
            p2 = new Point(50, 100);
            p3 = new Point(70, 100);
            p4 = new Point(250, 20);
            CanDrag = false;
            index = -1;
            font = this.Font;
        }

}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
自动控制节水灌溉技术的高低代表着农业现代化的发展状况,灌溉系统自动化水平较低是制约我国高效农业发展的主要原因。本文就此问题研究了单片机控制的滴灌节水灌溉系统,该系统可对不同土壤的湿度进行监控,并按照作物对土壤湿度的要求进行适时、适量灌水,其核心是单片机和PC机构成的控制部分,主要对土壤湿度与灌水量之间的关系、灌溉控制技术及设备系统的硬件、软件编程各个部分进行了深入的研究。 单片机控制部分采用上下位机的形式。下位机硬件部分选用AT89C51单片机为核心,主要由土壤湿度传感器,信号处理电路,显示电路,输出控制电路,故障报警电路等组成,软件选用汇编语言编程。上位机选用586型以上PC机,通过MAX232芯片实现同下位机的电平转换功能,上下位机之间通过串行通信方式进行数据的双向传输,软件选用VB高级编程语言以建立友好的人机界面。系统主要具有以下功能:可在PC机提供的人机对话界面上设置作物要求的土壤湿度相关参数;单片机可将土壤湿度传感器检测到的土壤湿度模拟量转换成数字量,显示于LED显示器上,同时单片机可采用串行通信方式将此湿度值传输到PC机上;PC机通过其内设程序计算出所需的灌水量和灌水时间,且显示于界面上,并将有关的灌水信息反馈给单片机,若需灌水,则单片机系统启动鸣音报警,发出灌水信号,并经放大驱动设备,开启电磁阀进行倒计时定时灌水,若不需灌水,即PC机上显示的灌水量和灌水时间均为0,系统不进行灌水。
智慧农业是一种结合了现代信息技术,包括物联网、大数据、云计算等,对农业生产过程进行智能化管理和监控的新模式。它通过各种传感器和设备采集农业生产中的关键数据,如大气、土壤和水质参数,以及生物生长状态等,实现远程诊断和精准调控。智慧农业的核心价值在于提高农业生产效率,保障食品安全,实现资源的可持续利用,并为农业产业的转型升级提供支持。 智慧农业的实现依赖于多个子系统,包括但不限于设施蔬菜精细化种植管理系统、农业技术资料库、数据采集系统、防伪防串货系统、食品安全与质量追溯系统、应急追溯系统、灾情疫情防控系统、农业工作管理系统、远程诊断系统、监控中心、环境监测系统、智能环境控制系统等。这些系统共同构成了一个综合的信息管理和服务平台,使得农业生产者能够基于数据做出更加科学的决策。 数据采集是智慧农业的基础。通过手工录入、传感器自动采集、移动端录入、条码/RFID扫描录入、拍照录入以及GPS和遥感技术等多种方式,智慧农业系统能够全面收集农业生产过程中的各种数据。这些数据不仅包括环境参数,还涵盖了生长状态、加工保存、检验检疫等环节,为农业生产提供了全面的数据支持。 智慧农业的应用前景广阔,它不仅能够提升农业生产的管理水平,还能够通过各种应用系统,如库房管理、无公害监控、物资管理、成本控制等,为农业生产者提供全面的服务。此外,智慧农业还能够支持政府监管,通过发病报告、投入品报告、死亡报告等,加强农业产品的安全管理和质量控制。 面对智慧农业的建设和发展,存在一些挑战,如投资成本高、生产过程标准化难度大、数据采集和监测的技术难题等。为了克服这些挑战,需要政府、企业和相关机构的共同努力,通过政策支持、技术创新和教育培训等手段,推动智慧农业的健康发展。智慧农业的建设需要明确建设目的,选择合适的系统模块,并制定合理的设备布署方案,以实现农业生产的智能化、精准化和高效化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值