安卓Socket連接實現連接實現發送接收數據,openwrt wifi轉串口連接單片機實現控制

来源:http://www.cnblogs.com/xiaobo-Linux/archive/2016/06/22/5606735.html
-Advertisement-
Play Games

安卓Socket連接實現連接實現發送接收數據,openwrt wifi轉串口連接單片機實現控制 socket 連接採用流的方式進行發送接收數據,採用thread線程的方式。 什麼是線程? 詳細代碼介紹: 博文來源:http://blog.csdn.net/zhaocundang 如果你對代碼有些疑問 ...


安卓Socket連接實現連接實現發送接收數據,openwrt wifi轉串口連接單片機實現控制

socket 連接採用流的方式進行發送接收數據,採用thread線程的方式。

什麼是線程? 
這裡寫圖片描述

詳細代碼介紹:

博文來源:http://blog.csdn.net/zhaocundang 如果你對代碼有些疑問,請在下麵留言來探討,或者加我的QQ463431476一起學習進步!

  //線程mRunnable啟動
        private Runnable    mRunnable   = new Runnable() 
            {
                public void run()
                {
                      try 
                    {               
                        //連接伺服器
                        mSocketClient = new Socket(wifiurl,Integer.parseInt(wificom)); 
                        //取得輸入、輸出流
                        mBufferedReaderClient = new BufferedReader(new InputStreamReader(mSocketClient.getInputStream()));
                        mPrintWriterClient = new PrintWriter(mSocketClient.getOutputStream(), true);
                        recvMessageClient = "wifi成功連接";//消息換行
                    // Toast.makeText(getActivity(),"wifi連接成功",Toast.LENGTH_SHORT).show();
                        Message msg = new Message();
                        msg.what = 1;
                        mHandler.sendMessage(msg);               
                    }
                    catch (Exception e) 
                    {
                        recvMessageClient = "連接錯誤!";//消息換行
                        Message msg = new Message();
                        msg.what = 1;
                        mHandler.sendMessage(msg);
                        return;
                    }   
                      setRecvMessage();
                }
            };


       public void setRecvMessage(){    
            char[] buffer = new char[256];
            int count = 0;
            while (true)
            {
                try
                {
                     if((count = mBufferedReaderClient.read(buffer))>0)
                    {                       
                        recvMessageClient = getInfoBuff(buffer, count);
              //將接收的數據放入數組 Thread.sleep(500); Message msg = new Message(); msg.what = 1; mHandler.sendMessage(msg); } } catch (Exception e) { recvMessageClient = "接收異常:" + e.getMessage() + "\n";//消息換行 Message msg = new Message(); msg.what = 0; mHandler.sendMessage(msg); } } } //handler用於線程中更新界面數據 Handler mHandler = new Handler() { public void handleMessage(Message msg) { super.handleMessage(msg); if(msg.what == 0) { Toast.makeText(getActivity(),recvMessageClient,Toast.LENGTH_SHORT).show();//刷新消息機制 } else if(msg.what == 1) { try { //// String result = recvMessageClient; // Toast.makeText(getActivity(),result,Toast.LENGTH_SHORT).show(); //接收消息的 String [] results = recvMessageClient.split("\\.");; // Toast.makeText(getActivity(),results[3],Toast.LENGTH_SHORT).show(); //接收消息的 /* Intent intent=new Intent(); intent.putExtra("temp",results[0]); intent.putExtra("humi",results[2]); intent.setAction("zcd.netanything.temp"); getActivity().sendBroadcast(intent); */ }catch(Exception e) { // Toast.makeText(getActivity(),"無法獲取數據,檢查網路是否連接!",Toast.LENGTH_SHORT).show();//刷新消息機制 } } } }; //接收處理 private String getInfoBuff(char[] buff, int count) { char[] temp = new char[count]; for(int i=0; i<count; i++) { temp[i] = buff[i]; } return new String(temp); } /*public void onDestroy() { super.onDestroy(); if (isConnect) { isConnect = false; try { if(mSocketClient!=null) { mSocketClient.close(); mSocketClient = null; //mThreadvideo.destroy(); mPrintWriterClient.close(); mPrintWriterClient = null; recvMessageClient = "網路埠成功";//消息換行 Message msg = new Message(); msg.what = 0; mHandler.sendMessage(msg); } } catch (IOException e) { e.printStackTrace(); } mThreadClient.interrupt(); } } */

 

按鍵觸發,開啟線程:

  public void onClick(View v) {
        // TODO Auto-generated method stub
        switch(v.getId()){
        case R.id.button1:
            mPrintWriterClient.print("f");
            //mPrintWriterClient.print("t");
            mPrintWriterClient.flush();//清空
         Toast.makeText(getActivity(),"前進",Toast.LENGTH_SHORT).show();
         break;
        case R.id.button2:
             mPrintWriterClient.print("b");
            // mPrintWriterClient.print("t");
             mPrintWriterClient.flush();
             Toast.makeText(getActivity(),"後退",Toast.LENGTH_SHORT).show();

            break;
        case R.id.button3:
            mPrintWriterClient.print("l");
        //  mPrintWriterClient.print("t");
            mPrintWriterClient.flush();
            Toast.makeText(getActivity(),"向左",Toast.LENGTH_SHORT).show();
            break;
        case R.id.button4:
            mPrintWriterClient.print("r");
        //  mPrintWriterClient.print("t");
            mPrintWriterClient.flush();  
            Toast.makeText(getActivity(),"向右",Toast.LENGTH_SHORT).show();
            break;
        case R.id.button5:
             if(!isConnect)
          {
            //開啟mThreadClient線程
            mThreadClient = new Thread(mRunnable);
            mThreadClient.start(); 
           Toast.makeText(getActivity(),"嘗試連接網路",500).show();
          }
          else {
              onDestroy();
              isConnect=false;

             }

            break;
        //case R.id.button6:
            //關閉wifi
        /*  if (isConnect) 
            {               
                isConnect = false;
                try {
                    if(mSocketClient!=null)
                    {
                        mSocketClient.close();
                        mSocketClient = null;
                        //mThreadvideo.destroy();
                        mPrintWriterClient.close();
                        mPrintWriterClient = null;
                        recvMessageClient = "網路埠成功";//消息換行
                        Message msg = new Message();
                        msg.what = 0;
                        mHandler.sendMessage(msg);
                    }
                } catch (IOException e) {
                    e.printStackTrace();
                }
                mThreadClient.interrupt();
            }
             */
            //   break;
        }
    }  

 

項目演示:

APP控制小車視頻演示

APP物聯繫統視頻演示


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 安卓請求網路的三種方式 在請求網路的時候一般常用的提交方式是post或者get請求,post請求安全,傳輸大小無限制,但是代碼量多些,get請求是瀏覽器有大小限制,用戶提交的信息在瀏覽器的地址欄顯示出來因此不安全 在Android中聯網請求需要添加許可權,4.0以後需要開啟一個線程,在網路請求的時候都 ...
  • App Store: 天的故事 1. 改回經典圖標和名稱 2. 界面優化,統一風格 3. 今日100載入故事更加智能 4. 性能優化,修複bug App Store: 天的故事 ...
  • 前段時間開發遇到webView 高度自適應問題,用最初的方法無效,找了些資料,記錄下。 1、若網頁中含有< !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/x ...
  • 一、什麼是RunLoop? RunLoop是運行迴圈,每個Cocoa應用程式都由一個處於阻塞狀態的do/while迴圈驅動,當有事件發生時,就把事件分派給合適的監聽器,如此反覆直到迴圈停止。處理分派的對象就叫做“運行迴圈”。 基本作用:1、保持程式的持續運行 2、處理App中的各種事件(比如觸摸事件 ...
  • 現實情況如上所示 我出現這種情況的原因有兩種: 其一:沒有給textview對齊方式; 其二:沒有將BOOL類型的“ automaticallyAdjustsScrollViewInsets ”屬性置為yes ...
  • Android動態調試七武器系列文章——Hooking下篇,分享一些常用或原創的調試工具以及手段,希望能對國內移動安全的研究起到一些催化劑的作用。 ...
  • 安卓使用SQlite3資料庫無法id主鍵無法自動增加?不是的。 要這樣寫:id integer primary key ,要寫integer而不是int所以會報錯! http://blog.csdn.net/zhaocundang SQLite幫助類中,這樣寫就可以id號自動增加 ...
  • 科大訊飛的語音識別功能用在安卓代碼中,我把語音識別寫成了Service,然後在Fragment直接調用service服務。科大訊飛語音識別用的是帶對話框的那個,直接調用科大訊飛的語音介面,代碼採用鏈表結果集的方式獲取數據。 這個語音識別需要在官網申請APPID 本博來自:http://blog.cs ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...