美文网首页Android开发经验谈Android技术知识Android开发
Android附近:如何集成Android和Android的东西

Android附近:如何集成Android和Android的东西

作者: Android姿态 | 来源:发表于2019-04-12 19:52 被阅读3次

    本文将探讨如何使用Android Nearby,展示如何集成Android和Android Things。我们可以使用几种策略来集成Android和Android Things。Android Nearby技术就是其中之一。Android提供了一组API,可以简化两个不同设备之间的数据交换。一个有趣的方面是Android Nearby也支持iOS操作系统。

    • Android Nearby是一项支持三种不同策略来集成Android设备的技术:

    • Android Nearby Messages:这使用发布者/订阅者范例在两个不同的Android设备之间交换简单的有效负载。
    • Android Nearby Connections:它是一个点对点网络,使应用程序能够在设备之间发现,连接和交换数据。这种策略支持高带宽,它可以在多种场景中使用(游戏,文件共享等)
    Android附近通知:此技术使用户可以使用应用或网站接收周围的通知
    本文介绍了如何使用Android Nearby Connections集成Android和Android Things设备。主要目标是展示如何将数据从Android智能手机发送到Android Things设备,并使用连接到Android Things的LCD显示屏显示此信息。

    Android Nearby简介
    Android Nearby连接是一个点对点网络。该网络有两个主要角色:

    • 通告自己等待传入连接的广告商
    • 寻找要连接的广告商的Discoverer
    一旦Discoverer找到了广告商,他们就可以建立连接并交换数据。在Android引擎盖下,Android Nearby API使用一组技术来建立不同设备之间的连接。它可以是蓝牙或Wi-Fi。API利用每种技术的优势来保证可靠的连接。开发人员和用户不必担心它,它是完全透明的。

    在本教程中,Android Things设备扮演等待传入Discoverer的广告商角色。Android设备是Discoverer,用于查找要连接的广告商。为了完成本教程,有必要实现两个不同的应用程序:

    Android Things应用程序,用于接收数据并处理LCD显示
    将数据发送到Android Things的Android应用
    此外,Android Nearby连接支持不同的发现和广告策略。一般来说,这两种策略是:

    • P2P_Cluster:支持M-to-N网络拓扑,其中每个设备都可以接受传入连接并启动与其他设备的新连接
    • P2P_STAR:这是一个经典的起始拓扑网络,其中一个设备作为广告商播放,其他设备是发现的
    在这个Android Things教程中,我们将使用P2P_STAR拓扑。让我们开始实施广告客户。


    使用Android Things的Android附近广告商


    第一步是使用Android Thing设备实施广告商。在这种情况下,我们将使用Raspberry Pi 3,但您可以使用与Android Things兼容的其他原型板。

    要实施Android Nearby Advertiser,我们必须遵循以下三个不同的步骤:

    开始做广告
    接受传入的连接
    收听传入的有效负载
    第四步是可选的,它正在管理连接到Android Things的LCD显示器,以便Android Things应用程序将在LCD显示器上显示有效载荷内容。


    使用Android Things开始广告


    第一件事是创建一个新类来处理所有Nearby连接细节。让我们称这个班 NearbyAdvManager。在构造函数中,Android Thing应用程序开始广告:

    私有 ConnectionsClient  客户端 ;
    ..
    客户 =  附近。getConnectionsClient(ctx);
    客户。startAdvertising(“ AndroidThings ”,
            SERVICE_ID,
            connectionLifeCycleCB,
            新 AdvertisingOptions(战略。P2P_STAR))
             。addOnSuccessListener(
               new  OnSuccessListener < Void >(){
                  @覆盖
                  public  void  onSuccess(Void  aVoid){
                    记录。我(TAG,“OnSuccess ......”);
                  }
               }
            )
            。addOnFailureListener(new  OnFailureListener(){
                @覆盖
                public  void  onFailure(@NonNull  Exception  e){
                   记录。e(TAG,“OnFailure 1”);
                   e。printStackTrace();
                }
          });
    }
    

    "Android Things"是昵称,而SERVICE_ID我们的服务ID。通常,SERVICE_ID是我们的应用程序的包名称。另一个参数connectionLifeCycleCB, 是回调类。

    请注意,Android Nearby有一组新的API。当我们创建广告商时,我们不再需要使用它 GoogleApiClient了。

    是时候实现连接回调,以便Android Things应用程序获得有关连接的通知。为此,我们将此代码添加到管理器:

    private  ConnectionLifecycleCallback  connectionLifeCycleCB  = 
       新的 ConnectionLifecycleCallback(){
         @覆盖
         public  void  onConnectionInitiated(String  s,
                       ConnectionInfo  connectionInfo){
           记录。我(标签,“连接发起。结束[” + s + “]”);
           //让我们接受这种联系
         }
         @覆盖
         public  void  onConnectionResult(String  s,
                ConnectionResolution  connectionResolution){
                记录。i(标签,“连接结果。结束[” + s + “]”);
          }
          @覆盖
          public  void  onDisconnected(String  s){
              记录。我(TAG,“Disconnected.Endpont [” + s + “]”);
          };
        };
    

    接受Android Things App中的传入连接


    一旦Android Things应用程序开始广告,就必须处理传入的连接。正如我们之前看到的,在连接回调接口中,我们有更改来处理连接。在onConnectionInitiated被称为当发现者要开始对广告客户的新连接。在此方法中,添加以下行:

    附近。getConnectionsClient(ctx)
              。acceptConnection(s,payloadCallback);
    

    使用此代码,Android Things应用程序可以接受所有传入连接,而无需使用身份验证机制。可以对客户端进行身份验证,以便我们可以应用某些安全策略。

    最后一步是传入,payloadCallback因此应用程序可以处理传入的有效负载。


    处理Android附近的有效负载


    这是Android Nearby Advertiser的最后一步。Android Things应用程序必须实现PayloadCallback接口以读取传入的有效负载。

    private  PayloadCallback  payloadCallback  =  new  PayloadCallback(){
        @覆盖
        public  void  onPayloadReceived(String  s,Payload  payload){
            记录。我(TAG,“收到有效负载”);
            byte [] b  =  有效载荷。asBytes();
            String  content  =  new  String(b);
            记录。我(标签,“内容[” + 内容+ “]”);
        }
        @覆盖
        public  void  onPayloadTransferUpdate(String  s,
               PayloadTransferUpdate  payloadTransferUpdate){
           记录。d(TAG,“有效载荷转移更新[” + s + “]”);
          }
    };
    

    在onPayloadReceived,我们将处理LCD显示屏以显示有效载荷内容。


    实现附近的Android事物应用程序


    经理准备好后,是时候实施Android Things Nearby应用了。让我们创建MainActivity课程:

    @覆盖
    protected  void  onCreate(Bundle  savedInstanceState){
      超。onCreate(savedInstanceState);
      记录。我(标签,“启动Android Things应用......”);
      NearbyAdvManager  advManager  =  new  NearbyAdvManager(this);
    }
    

    稍后,我们将处理连接到Android Things的LCD显示器,以便它可以显示有效载荷内容。

    在销毁应用程序时,不要忘记关闭连接并停止广告

    最后,我们可以要求权限了 AndroidManifest.xml

    < uses-permission  android:name = “android.permission.BLUETOOTH”  />
    < uses-permission  android:name = “android.permission.BLUETOOTH_ADMIN”  />
    < uses-permission  android:name = “android.permission.ACCESS_WIFI_STATE”  />
    < uses-permission  android:name = “android.permission.CHANGE_WIFI_STATE”  />
    < uses-permission  android:name = “android.permission.ACCESS_COARSE_LOCATION”  />
    

    您已准备好启动该应用。为此,您可以使用兼容的Android Things设备。在本教程中,我们将使用运行Android Things 1.0.3的Raspberry Pi 3。

    启动Android Things应用程序时,请确保这是第一个应用程序,否则您可能会遇到一些错误

    使用Nearby实现Android应用程序

    在本段中,我们将介绍如何实现播放Discoverer角色并将数据发送到Android Things应用的Android应用。实现此应用程序的步骤与之前用于实现Android Things Nearyby应用程序的步骤几乎相同。让我们从创建一个名为的类开始NearbyDsvManager。本课程将管理所有详细信息,以便与Android Things应用程序一起发现,连接和交换数据。

    将此构造函数添加到此类:

    public  NearbyDsvManager(Context  ctx,final  EventListener  listener){
        这个。listener  =  listener ;
        这个。ctx  =  ctx ;
        记录。我(TAG,“NearbyDsvManager”);
        附近。getConnectionsClient(ctx)
             。startDiscovery(SERVICE_ID,
                endpointDiscoveryCB,
                新 DiscoveryOptions(战略。P2P_STAR))
                。addOnSuccessListener(
                     new  OnSuccessListener < Void >(){
                        @覆盖
                        public  void  onSuccess(Void  aVoid){
                            记录。我(TAG,“OnSuccess ......”);
                             听众。startDiscovering();
                         }
                     }
                )
               。addOnFailureListener(new  OnFailureListener(){
                   @覆盖
                   public  void  onFailure(@NonNull  Exception  e){
                      记录。e(TAG,“OnFailure”,e);
                      e。printStackTrace();
                   }
           });
    }
    

    这个类几乎与前面描述的相同。它开始发现试图找到准备交换数据的广告商。此外,在此类中,定义了一个回调接口,用于在发现和连接过程中通知调用者(MainActivity)有关事件的信息。此回调接口是:

    public  interface  EventListener {
       public  void  onDiscovered();
       public  void  startDiscovering();
       public  void  onConnected();
    }
    

    此外,Nearby API使用另一个回调接口来通知调用者有关发现状态的信息。在上面的代码中,列表是endpointDiscoveryCB:

    private  EndpointDiscoveryCallback  endpointDiscoveryCB  =  new  EndpointDiscoveryCallback(){
        @覆盖
        public  void  onEndpointFound(String  s,DiscoveredEndpointInfo  discoveredEndpointInfo){
           记录。我(TAG,“Endpoint found [” + s + “]。Connecting ....”);
           听众。onDiscovered();
           getConnection(s);
         }
        @覆盖
        public  void  onEndpointLost(String  s){
           记录。e(TAG,“终点丢失[” + s + “]”);
        }
     };
    

    将附

    近的Discoverer连接到附近的广告商

    Discoverer找到有效端点(由广告商提供)后,Discoverer会尝试启动连接getConnection(s),其中s是发现的端点:

    private  void  getConnection(String  endpointId){
       附近。getConnectionsClient(ctx)
           。requestConnection(endpointId,endpointId,connectionLifecycleCallback)
            。addOnSuccessListener(new  OnSuccessListener < Void >(){
                @覆盖
                public  void  onSuccess(Void  aVoid){
                   记录。d(TAG,“请求连接......”);
                }
            })
           。addOnFailureListener(new  OnFailureListener(){
                @覆盖
                public  void  onFailure(@NonNull  Exception  e){
                   记录。e(TAG,“请求连接时出错”,e);
             }
      });
    }
    

    在此方法中,Discoverer使用endpointId 上一步中发现的连接请求新连接 。此外,它还添加了一个新的回调接口,以了解何时建立连接或出现错误。

    private  ConnectionLifecycleCallback  connectionLifecycleCallback  = 
      新的 ConnectionLifecycleCallback(){
        @覆盖
        public  void  onConnectionInitiated(String  s,ConnectionInfo  connectionInfo){
           记录。i(标签,“连接到端点[” + s + “]”);
           NearbyDsvManager。这个。currentEndpoint  =  s ;
           附近。getConnectionsClient(ctx)。acceptConnection(s,payloadCallback);
       }
       @覆盖
       public  void  onConnectionResult(String  s,ConnectionResolution  connectionResolution){
         开关(connectionResolution。的getStatus()。getStatusCode()){
              大小写 ConnectionsStatusCodes。STATUS_OK:
                 听众。onConnected();
                 打破 ;
              大小写 ConnectionsStatusCodes。STATUS_CONNECTION_REJECTED:
                 记录。我(标签,“拒绝连接”);
                 打破 ;
              大小写 ConnectionsStatusCodes。STATUS_ERROR:
                  记录。我(标签,“连接错误”);
                   打破 ;
           }
       }
       @覆盖
       public  void  onDisconnected(String  s){}
    };
    

    建立连接并且双方都接受了连接后,该过程结束并且应用程序已准备好发送数据。这是将有效负载从Android应用程序发送到Android Things应用程序的方法:

    public  void  sendData(String  data){
       记录。i(TAG,“发送数据[” + 数据+ “]”);
       记录。i(TAG,“Current endpoint [” + currentEndpoint + “]”);
       if(currentEndpoint  !=  null){
          记录。d(TAG,“将数据发送到[” + data + “]”);
          有效 负载 =  有效负载。fromBytes(数据。的getBytes());
          附近。getConnectionsClient(ctx)。sendPayload(currentEndpoint,payload);
        }
    }
    

    就这样。

    实现Android App UI

    最后一步实现Android应用程序UI,以便用户可以插入有效负载并将其发送到Android Things应用程序(Nearyby广告商)。用户界面非常简单:

    <?xml  version =“1.0”encoding =“utf-8”?>
    < android.support.constraint.ConstraintLayout 
        xmlns:android = “http://schemas.android.com/apk/res/android”
        xmlns:app = “http://schemas.android.com/apk/res-auto”
        xmlns:tools = “http://schemas.android.com/tools”
        android:layout_width = “match_parent”
        android:layout_height = “match_parent”
        tools:context = “。MainActivity” >
        < TextView
            android:layout_width = “wrap_content”
            android:layout_height = “wrap_content”
            android:text = “内容”
            app:layout_constraintLeft_toLeftOf = “parent”
            app:layout_constraintTop_toTopOf = “parent”
            android:layout_marginTop = “8dp”
            android:id = “@ + id / txt” />
        < EditText
            android:layout_width = “wrap_content”
            android:layout_height = “wrap_content”
            android:提示 = “文字在这里”
            android:maxLength = “40”
            android:id = “@ + id / ed”
            app:layout_constraintTop_toBottomOf = “@ id / txt”
            android:layout_marginTop = “8dp” />
        < 按钮
            android:layout_width = “wrap_content”
            android:layout_height = “wrap_content”
            app:layout_constraintBottom_toBottomOf = “parent”
            app:layout_constraintLeft_toRightOf = “parent”
            app:layout_constraintRight_toLeftOf = “parent”
            android:id = “@ + id / btn”
            android:text = “发送” />
    </ android.support.constraint.ConstraintLayout >
    

    最后:

    @覆盖
    protected  void  onCreate(Bundle  savedInstanceState){
       超。onCreate(savedInstanceState);
       的setContentView(ř。布局。activity_main);
       BTN  =  findViewById(ř。ID。BTN);
       等 =(的EditText)findViewById(ř。ID。编);
       btn。setOnClickListener(新 景观。OnClickListener(){
         @覆盖
         public  void  onClick(查看 v){
            String  txt  =  et。getText()。toString();
            记录。d(TAG,“Txt [” + txt + “]”);
            dsvManager。sendData(txt);
          }
       });
    }
    

    将LCD显示器连接到Android Things

    此步骤是可选的,因为它描述了如何将LCD显示器连接到Android Things以显示从Android应用程序发送的内容有效负载。这个Android Things教程使用了Hd44780 LCD。更多细节,这款LCD基于HD44780芯片和PCF8574。有几个版本具有不同的显示尺寸,这个例子中的一个是20×4。这是一个I2C外设,使用四个不同的引脚连接到Android Things板:

    • Vcc(+ 5V)
    • GND
    • SDA
    • CLK
    连接架构如下图所示:


    0000.png

    要管理此LCD,必须导入驱动程序。让我们将此行添加到build.gradle:

    实现 'com.leinardi.android.things:driver-hd44780:<version>'
    

    此外,有必要创建一个新类来处理LCD连接细节和显示数据的所有步骤

    公共 类 ManageLCD {
    私人 Hd44780  mLcd ;
    public  void  displayString(data){
       尝试 {
         记录。d(“LCd”,“写作”);
         if(mLCD  ==  null)
           MLCD   =  新 HD44780(“I2C1” ,0×27,HD44780。几何图形。LCD_20X4);
         mLcd。setBacklight(true);
         mLcd。cursorHome();
         mLcd。clearDisplay();
         mLcd。setText(data);
        } catch(例外 e){
          e。printStackTrace();
        }
      }
    }
    

    MainActivity当收到新的有效负载时,您必须在Android Things应用程序中调用此类。

    摘要

    最后,本文展示了如何使用Android Nearby连接不同的Android设备。本教程使用Android Nearby连接Android应用和Android Things应用,以便他们可以交换数据。此外,Android Things使用连接到它的LCD来显示来自Android应用程序的有效负载。希望您获得有关如何使用Android Nearby Advertiser和Discoverer以及如何按照Android Nearby规范连接它们的知识。

    相关文章

      网友评论

        本文标题:Android附近:如何集成Android和Android的东西

        本文链接:https://www.haomeiwen.com/subject/lslhwqtx.html