主頁 > 前端設計 > 物聯網測驗總結(11.6)

物聯網測驗總結(11.6)

2020-11-12 13:01:56 前端設計

物聯網測驗總結

功能說明:
1、可以同時實作兩個ESP32的ADC資料的讀取和顯示,并且可以將采集的資料發送到所連接資料庫和所系結的Onenet云平臺設備上,
2、可以pc同時與實作兩個ESP32進行TCP通行,并且可以將采集的資料發送到所連接資料庫和所系結的Onenet云平臺設備上,可查詢云端資料,

class1.cs 程式

class db 資料庫的類撰寫

 class db  //database資料庫的類,用于后面進行實體化,
    {
        static SqlConnection conn;  //創建一個用于連接打開資料庫的靜態變數--conn
        public static Boolean Is_OK;  //創建一個布爾型別的公共靜態變數--Is_OK

        public static void Open_db()  //在資料庫類--db 中類中創建一個名為公共靜態型別的方法--Open_db
        {
            //嘗試連接到資料庫
            try
            {
                //server=.\SQLEXPRESS;
                string ConStr = "server=.;database=test;uid=sa;pwd=`sql2012"; //定義資料庫的,名,登錄用戶名,密碼
                conn = new SqlConnection(ConStr);//連接到資料庫
                conn.Open();//打開資料庫的連接
            }
            嘗試連接到資料庫失敗,彈出  "連接資料庫失敗" 視窗,
            catch
            {
                MessageBox.Show("連接資料庫失敗");
            }
        }


        //上傳資料到資料庫
        //下面這個程式我改了,多加了幾個變數,更加的好用了

        //定義添加資料到資料庫的方法--Insert_data( id 為資料的名稱如:ADC1, val 為ADC對應的數值,dt 為對應的發送時間,dbname 為對應的資料庫名如歷史資料表, xuhao 為資料表里的序號變數, 
        //                                      value 為資料表里的當前值變數, date 為資料表里的時間變數   )
        public static void Insert_data(int id, double val, DateTime dt, string dbname, string xuhao, string value, string date)
        {

            if (conn.State == ConnectionState.Open)//檢測資料庫當前狀態是否打開
            {
                SqlCommand cmd = new SqlCommand();//初始化一個client(用戶)型別的資料庫變數
                cmd.Connection = conn;//
                //string table = "[歷史資料表" + dt.ToString("yyMMdd") + "]";

                string table = dbname;//吧資料庫的表名賦值給 table

                string strSQL = "INSERT INTO " + table + "(" + xuhao + "," + value + "," + date + ")"
                                + "VALUES (" + id + ", " + val
                                + ", '" + dt.ToString() + "')";//把所有的需要傳給資料庫的資料整合為一個長的字串賦值給strSQL

                cmd.CommandText = strSQL;  //插入資料SQL陳述句
                cmd.CommandType = CommandType.Text;//指定如何解釋字串
                cmd.ExecuteNonQuery();//回傳受影響的行數
                //int i = Convert.ToInt32(cmd.ExecuteScalar());
            }
        }
        internal static void Insert_data_2(int newid, double v, DateTime time)
        {
            throw new NotImplementedException();
        }
    }

TCP類的撰寫

什么是套接字呢?點擊這里查看!!!

 class myTcp//創建TCP的所用的類
    {
        public string strOut = "";//宣告一個字串型別的公共變數--strOut

        public string strIP = "127.0.0.1";//

        //初始化要連接的ip和埠號
        //public  IPEndPoint ipep = new IPEndPoint(IPAddress.Parse(strIP), 9050);

        //創建套接字
        public Socket server = new Socket(AddressFamily.InterNetwork,
            SocketType.Stream, ProtocolType.Tcp);//實體化套接字

        public void Tcp_Send(string str)//定義tcp發送資料的方法
        {
            if (server.Connected)//判斷是否連接到服務端
            {
                byte[] data = Encoding.UTF8.GetBytes(str);//將字串編碼為UTF8格式
                server.Send(data);//將資料發送到服務端
            }
        }

        public void Start()//打開tcp執行緒
        {
            //3.receive data
            //new Thread(Thread_Connect) { IsBackground = true }.Start();

            //當初始化一個執行緒,把Thread.IsBackground = true的時候,指示該執行緒為后臺執行緒,后臺執行緒將會隨著主執行緒的退出而退出,
            new Thread(Thread_Receive) { IsBackground = true }.Start();//上面的注釋很清楚了

        }
        void Thread_Receive()//獲取執行緒的回傳值
        {
            int recv = 0;//
            byte[] data = new byte[1024];//
            while (true)
            {
                if (server.Connected)//是否連接到server端
                {
                    try { recv = server.Receive(data); }//嘗試接收到緩沖區的資料
                    catch { }

                    strOut = Encoding.ASCII.GetString(data, 0, recv);  //獲取回傳值
                }
                Thread.Sleep(10);//延時10ms
            }
        }

    }

至此 class1.cs的主要兩個類程式寫完了,

Program.cs 程式

class DataPointTest //創建用于連接Onenet的類

  public class DataPointTest//創建用于連接Onenet的類
    {
        private const string url = "api.heclouds.com";//onenet的連接地址
        //public string appkey = "DXfTvFsU5RXxygkwddwvqFXhD3s=";//您在OneNET平臺的APIKey
        public string appkey = "5TK53JepiCvPJ4k79XrBti4YEtI=";//你的設備APIKey
        public string strOut = "";//

        public void TestAddNewDataPoint(int 設備號, string 資料流, string strVal)//創建傳輸到Onenet資料的方法
        {
            var client = new DefaultOneNETClient(url, appkey, "");//實體化OneNETClient(客戶端)
            var streams = new List<DataStreamSimple> //創建資料流變數
                          {
                              new DataStreamSimple
                              {
                                    ID = 資料流  ,
                                    Datapoints = new List<DataPointSimple>{
                                    new DataPointSimple
                                    {
                                        Value = strVal //賦值資料
                                    }
                                  }
                              }
                          };

            var data = new NewDataPointData { DataStreams = streams };//資料流賦值給data用于傳輸
            var req = new NewDataPointRequest { DeviceID = 設備號, Data = data };//發送資料請求
            var rsp = client.Execute(req);//發送資料并獲取回傳值
            Assert.IsFalse(rsp.IsError);//測驗Onenet回傳值是否正常
        }

        public void TestSearchDataPointWithCondition(string appkey1, string strDeviceID, string sensorName)//創建Onenet資料查詢的方法 變數分別為 APIKey ,設備號, 傳感器名
        {
            var client = new DefaultOneNETClient(url, appkey1, "");//實體化OneNETClient(客戶端)
            //測驗帶參查詢
            var req1 = new SearchDataPointRequest { DeviceID = strDeviceID, Protocol = Scheme.HTTP };
            req1.DataStreamId = "loc," + sensorName;
            var rsp1 = client.Execute(req1);
            Assert.IsFalse(rsp1.IsError);
            Assert.AreEqual(0, rsp1.Errno);
            Assert.AreEqual("succ", rsp1.Error);
            Assert.IsNotNull(rsp1.Data);
            //Assert.IsTrue(rsp1.Data.Count > 0);
            if (rsp1.Data.Count > 0) { 
                var val = rsp1.Data.Datastreams[0].Datapoints[0].GetValue();
                Console.WriteLine("帶參查詢結果:" + rsp1.Body);
                strOut = rsp1.Body;
            }
            else
            {
                strOut = "";
            }
        }

     
    }

Form1.cs 的程式

實作的效果

在這里插入圖片描述

class Form1 : Form //創建Form1的類

 public partial class Form1 : Form   //創建Form1的類
    {
        //FormList fLst = new FormList();
        //chart chart1 = new chart();

        SerialPort sp1 = new SerialPort();
        //SerialPort sp2 = new SerialPort();

        string dbname = "[歷史資料表一]";
        string xuhao = "系統序號01";
        string value = "當前值01";
        string date = "時間01";

        string strComm = "";

        public Form1()//Form1初始化
        {
            InitializeComponent();
        }
        private void btnSwitchSP_Click_1(object sender, EventArgs e)//打開/關閉串口按鈕的程式
        {
            if (btnSwitchSP.Text == "打開串口")
            {
                sp1.Close();
                sp1.PortName = textBox1.Text;
                sp1.BaudRate = 115200;
                try
                {
                    sp1.Open();//打開串口    
                    this.Text = "埠號:" + sp1.PortName + " 丨";
                    this.Text += "波特率:" + sp1.BaudRate + " 丨";
                }
                catch (Exception ex)
                {
                    MessageBox.Show("錯誤:" + ex.Message, "C#串口通信");
                }
                btnSwitchSP.Text = "關閉串口";
            }
            else
            {
                sp1.Close();//關閉串口
                btnSwitchSP.Text = "打開串口";
            }
        }



        private void Form1_Load(object sender, EventArgs e)//加載Form1視窗
        {
            btnSwitchSP_Click_1(sender, e);

        }

        private void timer2_Tick(object sender, EventArgs e)//視窗的定時器函式,定時發送資料
        {
            if (sp1.IsOpen)
            {
                if (strComm.Length  >= 15)   //保證接收位元組大于一定數目后再處理
                {
                    string str = strComm;  將輸入緩沖區中可用的位元組賦值給str 用于字串的分割和發送   // sp.ReadExisting();
                    txtRTC.Text = str;
                    textBox2.Text = str;

                    if (str != "")
                    {
                        string[] strArray = str.Split(new char[] { ',' });

                        if (listBox1.Items.Count > 0) listBox1.Items.Clear();
                        for (int i = 0; i < strArray.Length; i++)
                        {
                            if (strArray[i] != "")
                                listBox1.Items.Add(strArray[i]);
                        }

                        string KEY;
                        KEY = "\r\nADC:";
                        if (str.IndexOf(KEY) >= 0)
                        {
                            Find_KEY_01(str, KEY);     //查找關鍵字,并將A發送
                        }
                        else
                        {
                            KEY = "KEY:";
                            Find_KEY_01(str, KEY);     //查找關鍵字,并
                        }


                    }
                }

                strComm = ""; //清空已發送的字串流
            }
        }


         void sp1_ReadData()//用串口給esp32發送命令的方法
        {
            Thread.Sleep(10);
            string t = "from machine import Pin,ADC,RTC,Timer\r\n"
                    + "rtc = RTC()\r\n"
                    + "adc1 = ADC(Pin(33))\r\n"
                    + "adc2 = ADC(Pin(34))\r\n"
                    + "adc3 = ADC(Pin(35))\r\n";
            sp1.Write(t);
            Thread.Sleep(100);


            while (true)
            {

                try//防止程式崩潰的嘗試代碼
                {
                    if (sp1.IsOpen)
                    {
                        t = "d = rtc.datetime()\r\nprint(str('ADC:1,%.3f,'%(adc1.read()/4095))+str('TIME:%04d-%02d-%02d %02d:%02d:%02d.%03d'%(d[0],d[1],d[2],d[4],d[5],d[6],int(d[7]/1000))))\r\n,";
                        sp1.Write(t);//發生上述命令到ESP32
                        Thread.Sleep(100);

                        if (sp1.BytesToRead >= 10)
                        {
                            strComm = sp1.ReadExisting();    //從輸入緩沖區中取用立即可用的位元組
                    
                        }
                        t = "d = rtc.datetime()\r\nprint(str('ADC:2,%.3f,'%(adc2.read()/4095))+str('TIME:%04d-%02d-%02d %02d:%02d:%02d.%03d'%(d[0],d[1],d[2],d[4],d[5],d[6],int(d[7]/1000))))\r\n,";
                        sp1.Write(t);//發生上述命令到ESP32
                        Thread.Sleep(100);
                        if (sp1.BytesToRead >= 10)
                            strComm = sp1.ReadExisting();

                        t = "d = rtc.datetime()\r\nprint(str('ADC:3,%.3f,'%(adc3.read()/4095))+str('TIME:%04d-%02d-%02d %02d:%02d:%02d.%03d'%(d[0],d[1],d[2],d[4],d[5],d[6],int(d[7]/1000))))\r\n,";
                        sp1.Write(t);//發生上述命令到ESP32
                        Thread.Sleep(100);
                        if (sp1.BytesToRead >= 10)
                            strComm = sp1.ReadExisting();//從串口的緩沖區里讀取ESP32回傳的數值
                    }
                }

                catch
                {
                    if (!sp1.IsOpen)
                    {
                        break;
                    }
                }
                Thread.Sleep(1);    //防止串口沒有打開時,執行緒死鎖
            }
        }
   

        private void BtnClear_Click(object sender, EventArgs e)
        {
            axTChart1.Series(0).Clear();
            axTChart1.Series(1).Clear();
            axTChart1.Series(2).Clear();
        }

        public void AddToChart(int id, double v, DateTime time)//將接受到的ESP32的ADC數值添加到圖表中
        {
            if (id >= 0 && id <= 2) {
                axTChart1.Series(id).Add(v, time.ToString("HH:mm:ss"), 1);//共三條
            }
        }

        void Find_KEY_01(string str, string KEY1)//找到關鍵字
        {
            //string KEY1 = "KEY:";
            int index1 = str.IndexOf(KEY1);     //在字串 str 中索引關鍵字 KEY1 并將此字串所在位作為 索引 0                 **IndexOf(索引的物件,開始的索引號);**
            string KEY2 = ",TIME:";             //定義關鍵字 KEY2 為 ",TIME:"  
            int index2 = str.IndexOf(KEY2);     //在字串 str 中索引關鍵字  ",TIME:" 并將此字串所在位作為 索引 0
            if (index1 >= 0 && index2 >= 0)     //索引到關鍵字 
            {
                int pos0 = str.IndexOf(",", index1 + KEY1.Length);//取接收到的字串的第一個逗號為索引
                if (pos0 >= 0)
                    label2.Text = str.Substring(index1 + KEY1.Length, pos0 - (index1 + KEY1.Length));    //取出 KEY1 打頭 ,結尾的一段字串

                int pos1 = str.IndexOf(",", pos0 + 1);
                if (pos1 >= 0)
                    label3.Text = str.Substring(pos0 + 1, pos1 - (pos0 + 1)); //取出 0號逗號和1號 之間的 字串

                int pos2 = str.IndexOf(",", index2 + KEY2.Length);
                if (pos2 >= 0)
                {
                    label4.Text = str.Substring(index2 + KEY2.Length, 23);      // pos2 - (index2 + KEY2.Length)-2);  //取出 KEY1 打頭 ,結尾的一段字串
                    if (KEY1 == "\r\nADC:")                                     
                    {
                        int id = Convert.ToInt32(label2.Text);           //將label2.Text字串型別值轉換為32位整型賦給id
                        double v = Convert.ToDouble(label3.Text);        //將label3.Text字串型別值轉換為雙精度型賦給v
                        DateTime time = Convert.ToDateTime(label4.Text); //將label4.Text字串型別值轉換為時間型別賦給time
                        if (label2.Text == "1")
                        {
                        }

                        db.Insert_data(id, v, time, dbname, xuhao, value, date); //上傳資料到資料庫 1
                        //db.Insert_data(id, v, time,dbname);  //上傳資料庫 1
                        AddToChart(id,v, time);

                        DataPointTest dp = new DataPointTest();
                        dp.appkey = "5TK53JepiCvPJ4k79XrBti4YEtI=";//APIKEY
                        int devid = 561695299;                                      //設備號
                        dp.TestAddNewDataPoint(devid, "ADC" + id, v.ToString());    //***發送ADC資料到onenet云平臺***

                        //資料串列
                        //fLst.AddToListView(label2.Text, label3.Text, label4.Text);
                        //fLst.Show();
                    }

                }

            }
        }


        private void button2_Click(object sender, EventArgs e)  //初始化ESP32_01按鈕程式
        {
           
                Thread thread_sp1 = new Thread(new ThreadStart(sp1_ReadData));
                thread_sp1.Start();
          
        }

        private void button3_Click(object sender, EventArgs e)//FormDB_01按鈕
        {
            FormDB_01 f = new FormDB_01();
            f.Show();
        }

        private void button4_Click(object sender, EventArgs e)//查詢按鈕未使用
        {

        }

        private void btn_添加_Click(object sender, EventArgs e)// btn_添加_Click按鈕程式
        {
            DataPointTest dp = new DataPointTest();
            dp.appkey = "3=Uaw=REPGSubU=rwVj8x=Hbb58=";
            dp.TestAddNewDataPoint(Convert.ToInt32(txt設備號.Text), txt傳感器名.Text, txt數值.Text);

        }

    }

FromTCP.cs的程式

實作效果

在這里插入圖片描述

class FormTCP : Form //創建TCP的類

 public partial class FormTCP : Form //創建TCP的類
    {
        myTcp tcp1 = new myTcp();
        public int Station_Number = 0;

        public FormTCP()
        {
            InitializeComponent();
        }

        private void btn_Connect_Click(object sender, EventArgs e)//連接按鈕程式
        {
            //if (tcp1.server.Connected)
            this.Text = "連接關閉!";
            tcp1.server.Close();
            Thread.Sleep(100);
            
            tcp1.server = new Socket(AddressFamily.InterNetwork,
            SocketType.Stream, ProtocolType.Tcp);

            IPEndPoint ipep = new IPEndPoint(IPAddress.Parse(txtIP.Text), Convert.ToInt16(txtPort.Text));//TCP終端初始化

            try//嘗試連接
            {
                if (!tcp1.server.Connected) 
                    tcp1.server.Connect(ipep);

                Thread.Sleep(10);
                if (tcp1.server.Connected)
                    this.Text = "連接成功!";
            }
            catch (SocketException e2) //連接例外處理
            {
                //this.Text = e2
                tcp1.server.Close();
            }

        }

        private void button1_Click(object sender, EventArgs e)//關閉連接 按鈕程式
        {
            try{
                tcp1.server.Close();
            }
            catch (SocketException e2) //連接例外處理
            {
            }
            this.Text = "連接關閉!";

        }

        private void label7_Click(object sender, EventArgs e)//TCP發送的label 程式
        {
            tcp1.Tcp_Send(textBox2.Text);//發送textBox里的資料到Server端
        }

        private void timer2_Tick(object sender, EventArgs e)//Tcp的定時器2的程式用于查找分割好的字串并發送資料到Onenet云平臺
        {

            if (tcp1.strOut != "")
            {
                string str = tcp1.strOut;
                textBox4.Text = str;
                if (str != "")
                {
                    string[] strArray = str.Split(new char[] { ',' });
                    string KEY;
                    KEY = "ADC:";
                    if (str.IndexOf(KEY) >= 0)
                    {
                        Find_KEY(str, KEY);
                    }
                    else
                    {
                        KEY = "KEY:";
                        Find_KEY(str, KEY);
                    }
                }
                tcp1.strOut = "";
            }

        }

        void Find_KEY(string str, string KEY1)//用于分割接收到的字串
        {
            //string KEY1 = "KEY:";
            int index1 = str.IndexOf(KEY1);
            string KEY2 = ",TIME:";
            int index2 = str.IndexOf(KEY2);
            string label2_Text="", label3_Text="",label4_Text=""; 
            if (index1 >= 0 && index2 >= 0)
            {
                int pos = str.IndexOf(",", index1 + KEY1.Length);
                if (pos >= 0)
                    label2_Text = str.Substring(index1 + KEY1.Length, pos - (index1 + KEY1.Length));

                int pos1 = str.IndexOf(",", pos + 1);
                if (pos1 >= 0)
                    label3_Text = str.Substring(pos + 1, pos1 - (pos + 1));

                int pos2 = str.IndexOf(",", index2 + KEY2.Length);
                if (pos2 >= 0)
                {
                    label4_Text = str.Substring(index2 + KEY2.Length, 23);      // pos2 - (index2 + KEY2.Length)-2);
                    if (KEY1 == "ADC:")
                    {
                        int id = Convert.ToInt32(label2_Text);
                        double v = Convert.ToDouble(label3_Text);
                        DateTime time = Convert.ToDateTime(label4_Text);

                        DataPointTest dp = new DataPointTest();
                        dp.appkey = "5TK53JepiCvPJ4k79XrBti4YEtI=";
                        int devid = 561695299;                                      //設備號
                        dp.TestAddNewDataPoint(devid, "ADC" + id, v.ToString());    //***發送ADC資料到onenet云平臺***


                        MainForm.Add_To_ListView_Form(Station_Number, id, v, time);//將資料添加到ListView_Form視窗

                    }

                }

            }
        }
        private void FormTCP_Load(object sender, EventArgs e)//打開TCP視窗時加載
        {
            tcp1.Start();
        }
        private void timer1_Tick(object sender, EventArgs e)//tcp定時器1的程式
        {
            if (checkBox回圈發送.Checked)   //回圈發送ADC1,ADC2,ADC3
            {
                for (int i = 1; i <= 3; i++)
                {
                    textBox2.Text = "ADC" + i;
                    Thread.Sleep(200);
                    tcp1.Tcp_Send(textBox2.Text);
                    
                }
            }
        }



    }

MainForm.cs 程式

實作效果

在這里插入圖片描述

class MainForm : Form

 public partial class MainForm : Form
    {
        protected Boolean stop = false;    
        protected Boolean conState = false;
        private StreamReader sRead;
        //Form1 f1 = new Form1();
        //Form1 f2 = new Form1();
        //Form1 f3 = new Form1();

        //FormList fLst = new FormList();

        string strRecieve;
        bool bAccept = false;
        SerialPort sp = new SerialPort();
 
        public static string strPortName = "";
        public static string strBaudRate = "";
        public static string strDataBits = "";
        public static string strStopBits = "";

        public static Form_ListView listViewForm;     // = new Form_ListView();
        public static FormTCP frmtcp1 = new FormTCP();
        public static FormTCP frmtcp2 = new FormTCP();
        public static chart frmChart1 = new chart();
        public static chart frmChart2 = new chart();





        public static void Add_To_ListView_Form(int Station_Number, int id, double v, DateTime time)
        {
            //if (gl_全域變數.Is_System_Exit) return;
            if (listViewForm == null) listViewForm = new Form_ListView();

            if (!listViewForm.Visible) listViewForm.Show();

            string t;
            //string str_MAC = ParseUtil.ToHexMAC(buf, 14, 6);
            string str_MAC = Station_Number + "_" + id;
            string str_KEY = "K" + str_MAC;

            string str_Time = time.ToString("HH:mm:ss.fff");
            if (listViewForm == null)
                listViewForm = new Form_ListView();

            int newid = Convert.ToInt32(Station_Number + "0" + id);
            string dbname = "[歷史資料表一]";
            string xuhao = "系統序號01";
            string value = "當前值01";
            string date = "時間01";
            db.Insert_data(newid, v, time, dbname, xuhao, value, date); //上傳資料庫 1

            if (Station_Number == 1)
            {
                frmChart1.AddToChart(id, v, time);
                if (!frmChart1.Visible) frmChart1.Show();
            }
            if (Station_Number == 2)
            {
                frmChart2.AddToChart(id, v, time);
                if (!frmChart2.Visible) frmChart2.Show();
            }

            //OneNet 使用新的傳感器序號 newid 101 、201
            //DataPointTest dp = new DataPointTest();
            //dp.appkey = "zsa=LDvUNxe6TUZq8M0V3HrA54k=";
            //int devid = 578091985;
            //dp.TestAddNewDataPoint(devid, "ADC" + newid, v.ToString());


            ListViewItem item = null;
            //if (listViewForm.listView1.Items.Count == 0){
            item = listViewForm.listView1.Items.Add("", listViewForm.listView1.Items.Count.ToString(), 0);

            t = str_Time;  //SubItems[1] 
            item.SubItems.Add(t);

            t = str_MAC;        // ParseUtil.ToHexMAC(buf, 15, 6);       //MAC SubItems[2]
            item.SubItems.Add(t);

            t = v.ToString();
            item.SubItems.Add(t);

            t = "";    //Header4 - 11
            item.SubItems.Add(t);
            item.SubItems.Add(t);
            item.SubItems.Add(t);
            item.SubItems.Add(t);
            item.SubItems.Add(t);
            item.SubItems.Add(t);
            item.SubItems.Add(t);
            item.SubItems.Add(t);

        }



        public MainForm()
        {
            InitializeComponent();
        }

        private void btnSetSP_Click(object sender, EventArgs e)//串口設定
        {
            timer1.Enabled = false;
            sp.Close();
        }



        private void btnSwitchSP_Click(object sender, EventArgs e)//打開串口
        {
            if (btnSwitchSP.Text == "打開串口")
            {
                if (strPortName != "" && strBaudRate != "" && strDataBits != "" && strStopBits != "")
                {
                    try
                    {
                        if (sp.IsOpen)
                        {
                            sp.Close();
                            sp.Open(); //打開串口    
                        }
                        else
                        {
                            sp.Open();//打開串口    
                        }
                        btnReceiveData_Click(sender,e);
                        btnSwitchSP.Text = "關閉串口";
                        groupBox1.Enabled = true;
                        groupBox2.Enabled = true;
                        this.toolStripStatusLabel1.Text = "埠號:" + sp.PortName + " 丨";
                        this.toolStripStatusLabel2.Text = "波特率:" + sp.BaudRate + " 丨";
                        this.toolStripStatusLabel3.Text = "資料位:" + sp.DataBits + " 丨";
                        this.toolStripStatusLabel4.Text = "停止位:" + sp.StopBits + " 丨";
                        this.toolStripStatusLabel5.Text = "";
                    }
                    catch (Exception ex)
                    {
                        MessageBox.Show("錯誤:" + ex.Message,"C#串口通信");
                    }
                }
                else
                {
                    MessageBox.Show("請先設定串口!","RS232串口通信");
                }
            }
            else
            {
                timer1.Enabled = false;
                btnSwitchSP.Text = "打開串口";
                sp.Close();
                groupBox1.Enabled = false;
                groupBox2.Enabled = false;
                this.toolStripStatusLabel1.Text = "埠號:埠未打開丨";
                this.toolStripStatusLabel2.Text = "波特率:埠未打開丨";
                this.toolStripStatusLabel3.Text = "資料位:埠未打開丨";
                this.toolStripStatusLabel4.Text = "停止位:埠未打開丨";
                this.toolStripStatusLabel5.Text = "";
            }
        }

  
        private void btnSendData_Click(object sender, EventArgs e)//資料發送
        {
            if (sp.IsOpen)
            {
                try
                {
                    sp.Encoding = System.Text.Encoding.GetEncoding("GB2312");//GB2312即資訊交換用漢字編碼字符集
                    sp.Write(txtSend.Text);
                }
                catch (Exception ex)//若應用程式出現除錯問題
                {
                    MessageBox.Show("錯誤:" + ex.Message);
                }
            }
            else
            {
                MessageBox.Show("請先打開串口!");
            }
        }


        delegate void DelegateAcceptData();
        void fun()
        {
            while (bAccept )
            { AcceptData(); }
        }

        delegate void reaction();
        void AcceptData()
        {
            if (textBox2.InvokeRequired)
            {
                try
                {
                    DelegateAcceptData ddd = new DelegateAcceptData(AcceptData);
                    this.Invoke(ddd, new object[] { });
                }
                catch { }
            }
            else
            {
                try
                {
                    strRecieve = sp.ReadExisting();
                    textBox2.Text += strRecieve;
                }
                catch (Exception e) { }
            }
        }
        
        private void btnReceiveData_Click(object sender, EventArgs e)//接受資訊
        {
            if (sp.IsOpen)
            {
                sp.Encoding = System.Text.Encoding.GetEncoding("GB2312");//GB2312即資訊交換用漢字編碼字符集
                timer2.Enabled = true;
            }
            else
            {
                MessageBox.Show("請先打開串口!");
            }
        }

        private void timer1_Tick(object sender, EventArgs e)
        {            
            string str1;
            str1 = sRead.ReadLine();
            if (str1 == null)
            {
                timer1.Stop();
                sRead.Close();
                MessageBox.Show("檔案發送成功!","C#串口通信");
                this.toolStripStatusLabel5.Text = "";
                return;
            }
            byte[] data = Encoding.Default.GetBytes(str1);
            sp.Write(data, 0, data.Length);
            this.toolStripStatusLabel5.Text = "        檔案發送中...";
        }

  
        private void btnOutputInfo_Click(object sender, EventArgs e)    //匯出資訊到檔案
        {
            try
            {
                string path = @"D:\output.txt";
                string content = this.textBox2.Text;
                FileStream fs = new FileStream(path, FileMode.OpenOrCreate, FileAccess.Write);
                StreamWriter write = new StreamWriter(fs);
                write.Write(content);
                write.Flush();
                write.Close();
                fs.Close();
                MessageBox.Show("接收資訊匯出在" + path);
            }
            catch (Exception exp)
            {
                MessageBox.Show(exp.ToString());
            }
        }

        private void btnClearInfo_Click(object sender, EventArgs e)//清空接受區
        {
            this.textBox2.Text = "";
        }

        private void btnQueryFile_Click(object sender, EventArgs e)//設定檔案路徑
        {
            String filename;
            OpenFileDialog Open1 = new OpenFileDialog(); 
            Open1.FileName = "";
            Open1.ShowDialog();
            filename = Open1.FileName;

            if (filename == "")
            {
                MessageBox.Show("請選擇要發送的檔案!", "Error");
                return;
            }
            textBox1.Text = filename;

            if (filename != null)
            {
                StreamReader sRead = new StreamReader(filename);
            }
            btnReceiveData.Enabled = true;

        }

        private void btnSendFile_Click(object sender, EventArgs e)//檔案發送
        {
            string fileName = textBox1.Text;

            if (fileName == "")
            {
                MessageBox.Show("請選擇要發送的檔案!", "Error");
                return;
            }
            else
            {
                sRead = new StreamReader(fileName);
            }
            timer1.Start();
        }
 
        private void timer2_Tick(object sender, EventArgs e)
        {
            if (sp.IsOpen)
            {
                string str = sp.ReadExisting();
                string str4 = str.Replace("\r", "\r\n");
                textBox2.AppendText(str4);
                textBox2.ScrollToCaret();
            }
        }


        private void MainForm_Load(object sender, EventArgs e)
        {
            groupBox1.Enabled = false;
            groupBox2.Enabled = false;
            this.toolStripStatusLabel1.Text = "埠號:埠未打開丨";
            this.toolStripStatusLabel2.Text = "波特率:埠未打開丨";
            this.toolStripStatusLabel3.Text = "資料位:埠未打開丨";
            this.toolStripStatusLabel4.Text = "停止位:埠未打開丨";
            this.toolStripStatusLabel5.Text = "";
        }

        private void btn_Form1_Click(object sender, EventArgs e)
        {
            Form1 f1 = new Form1();
            f1.Show();
            //f1.Left = this.Left-500;
            //f1.Top = this.Top + 100;
            f1.Text = "COM1";
            //f1.textBox1.Text = "COM1";
            //f1.textBox1.Text = "COM1";
        }

        private void button3_Click_1(object sender, EventArgs e)
        {
            Form2 f2 = new Form2();
            f2.Show();
            //f2.Left = this.Left - 500;
            //f2.Top = this.Top + 100;
            f2.Text = "COM2";

        }


        private void btn_FormList_Click(object sender, EventArgs e)
        {
            //fLst.Show();
        }

        private void button1_Click(object sender, EventArgs e)
        {
            FormDB_01 f = new FormDB_01();
            f.Show();
        }

        private void button2_Click(object sender, EventArgs e)
        {
            FormTCP frmtcp1 = new FormTCP();
            frmtcp1.txtIP.Text = "10.1.1.64";
            frmtcp1.txtPort.Text = "10000";
            frmtcp1.Station_Number = 1;
            frmtcp1.Text = "TCP" + frmtcp1.Station_Number;
            frmtcp1.Show();
            frmtcp1.Left = this.Left + this.Width;
            //f1.Top = this.Top + 500;


            FormTCP frmtcp2 = new FormTCP();
            frmtcp2.txtIP.Text = "10.1.1.52";
            frmtcp2.txtPort.Text = "10000";
            frmtcp2.Station_Number = 2;
            frmtcp2.Text = "TCP" + frmtcp2.Station_Number;
            frmtcp2.Show();
            frmtcp2.Left = frmtcp2.Left;
            //frmtcp2.Top = frmtcp2.Top + 500;

        }

        private void btn打開Tcp_Server_Click(object sender, EventArgs e)
        {
            FormTcpServer f1 = new FormTcpServer();
            f1.txtIP.Text = "127.0.0.1";
            f1.txtPort.Text = "9050";
            f1.Show();
            f1.Left = this.Left + this.Width;
            //f1.Top = this.Top + 500;

        }        
    }

FromDB.cs 程式

實作效果

在這里插入圖片描述

class FormDB_01 : Form 實作代碼

public partial class FormDB_01 : Form
    {
        public FormDB_01()
        {
            InitializeComponent();
        }

        private void FormDB_01_Load(object sender, EventArgs e)
        {
            // TODO:  這行代碼將資料加載到表“testDataSet.歷史資料表一”中,您可以根據需要移動或洗掉它,
            this.歷史資料表一TableAdapter.Fill(this.testDataSet.歷史資料表一);
          
            

        }

        private void button1_Click(object sender, EventArgs e)
        {
            DataPointTest dp = new DataPointTest();
            dp.TestSearchDataPointWithCondition(txt_APIKEY.Text, txt設備號.Text, comboBox1.Text);      //查詢 發送到onenet云平臺的資料
            textBox2.Text = dp.strOut;
            textBox2.Text = dp.strOut;
        }

    }

by iNBC form SDUT(2020.11.11 pm11:00)

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/211920.html

標籤:其他

上一篇:【Microstation】三維建模基礎及軟體入門到精通實驗教程目錄

下一篇:人人都是好朋友

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more