自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

使用Xamarin和Visual Studio開發(fā)Android可穿戴設(shè)備應用

譯文
移動開發(fā) Android
在本文中,我將向您詳細介紹使用Xamarin和Visual Studio開發(fā)Android可穿戴設(shè)備應用程序的完整過程。

搭建開發(fā)環(huán)境

我們需要做的第一件事情是安裝必要的工具。因此,你需要首先安裝Visual Studio。如果您使用的是Visual Studio 2010,2012或2013,那么請確保它是一個專業(yè)版本或更高級版本,因為Visual Studio的Xamarin擴展并不支持精簡版。有關(guān)詳細信息,請參閱 https://xamarin.com/faq。

對我本人來說,使用了Visual Studio 2013 Untimate版本。一旦你已經(jīng)安裝了受支持的 Visual Studio版本,那么請接著下載Visual Studio的Xamarin擴展(下載地址是http://xamarin.com/visual-studio)。(你可以免費試用或申請一個許可證版本)。

接下來的操作,只需按照下載的向?qū)е械恼f明進行即可,直到安裝完全為止。為了正常使用擴展,您可能需要重新啟動您的計算機。

現(xiàn)在,當您正常啟動Visual Studio,你應該能夠在工具菜單下看到如圖所示的以下項目。

圖1:Android Tools和SDK

為確保您所需要的一切已經(jīng)正常安裝,您可以通過Android SDK Manager來驗證。為此,只需打開Tools > Android > Android SDK Manager。這將打開下圖所示的窗口:

圖2:Android SDK Manager

現(xiàn)在,在確保你已經(jīng)安裝所需要的一切后,接下來你可以開始使用Visual Studio中的Xamarin創(chuàng)建你自己的Android應用程序了。

創(chuàng)建簡單的Android可穿戴設(shè)備應用

首先,讓我們創(chuàng)建一個新的Visual Studio項目,然后從模板中選擇Android > Wear App (Android)。你應該能夠看到如下圖所示的東西。

圖3:Visual Studio模板列表

現(xiàn)在,只需單擊OK命令讓Visual Studio為你生成創(chuàng)建可穿戴應用程序所需的文件。下面的圖像顯示了默認生成的文件。注意:其中提供了你著手構(gòu)建可穿戴應用程序的示例代碼。

圖4:默認的可穿戴應用程序代碼

很容易吧!官方文檔中提供的有關(guān)Xamarin.Android應用程序分析的資料對應的URL是http://developer.xamarin.com/guides/android/getting_started/。

運行程序

為了在不需要真實設(shè)備的情況下即可運行應用程序,我們首先需要建立一個模擬器程序。您可以通過以下幾個步驟創(chuàng)建模擬器程序。

轉(zhuǎn)到命令Tools > Andriod > Andriod Emulator Manager或單擊工具欄上的AVD圖標。請參閱下圖。

圖5:Andriod內(nèi)置模擬器程序

之后,應顯示安卓系統(tǒng)設(shè)備管理器窗口。在這里,我們可以編輯、啟動、 創(chuàng)建、刪除或修復虛擬設(shè)備。

現(xiàn)在,我們需要單擊"Create"按鈕。下圖中的窗口應打開,允許您選擇您想要創(chuàng)建的設(shè)備。在本例中,我們只需要創(chuàng)建一個虛擬Android可穿戴設(shè)備,用于在模擬器上運行我們的應用程序。

圖6:AVD對話框

一旦一切設(shè)置好,只需單擊OK便可創(chuàng)建虛擬設(shè)備。在下圖中,你應該能夠看到您剛通過AVD管理器創(chuàng)建的設(shè)備。

圖7:AVD管理器

現(xiàn)在,只需單擊命令Start > Launch便可在后臺運行模擬程序。注意,系統(tǒng)可能需要一些時間來加載模擬器。模擬程序加載并準備好之后,你應該能夠看到您剛創(chuàng)建的虛擬設(shè)備的名稱顯示于開始調(diào)試下拉列表中。

圖8:新創(chuàng)建的虛擬設(shè)備

現(xiàn)在,將您的應用程序設(shè)置為啟動項目,然后按F5鍵運行它。下圖展示了示例可穿戴應用程序在模擬器程序中的輸出結(jié)果。

圖9:輸出

請記住,集成到Visual Studio內(nèi)部的默認模擬器速度有點慢,僅適用于測試小型應用程序。在實際開發(fā)中創(chuàng)建并測試應用程序的話,我會推薦你使用Xamarin安卓播放機(https://developer.xamarin.com/guides/android/deployment,_testing,_and_metrics/debug-on-emulator/)來模擬android應用程序。

就這樣!如果您想要參考更多的可穿戴設(shè)備應用程序?qū)嵗?,只需訪問此鏈接:http://developer.xamarin.com/samples/android/Android%20Wear/

同步Android可穿戴設(shè)備和手持設(shè)備間的數(shù)據(jù)

讓我們再努力一點,創(chuàng)建一個支持在您的可穿戴程序和手持設(shè)備之間進行通信的可工作的應用程序。這個練習將演示如何同步你的安卓應用程序之間的數(shù)據(jù)。

創(chuàng)建Android可穿戴設(shè)備程序

開始,讓我們啟動Visual Studio 2013,然后選擇命令"File" -> "New" -> "Project..."。在模板中選擇 C# > Android并選擇Wear App (Android) Project。

命名您的應用程序,然后單擊OK讓Visual Studio為您生成所需的文件。在本練習中,程序名為"WearDemo"。下面的圖像顯示了默認示例代碼生成的文件,用于幫助您編寫可穿戴設(shè)備應用程序。

圖 10:可穿戴設(shè)備應用程序項目

在我們開始修改默認代碼之前,我想指出:有兩種方法可以實現(xiàn)可穿戴設(shè)備和手持設(shè)備之間進行通信,分別是DataApi和MessageApi。以下是每個API的簡短描述。

DataApi:它所輸出的API供組件讀取或?qū)懭霐?shù)據(jù)項(Items)及相關(guān)資源(Assets)。其中,DataItem提供數(shù)據(jù)存儲,支持掌上電腦和手持設(shè)備之間自動同步。Assets用于發(fā)送例如圖像這樣的Blob數(shù)據(jù)。你只需要將Assets關(guān)聯(lián)到DataItems,則系統(tǒng)會自動為你實現(xiàn)其他的處理。有關(guān)細節(jié),請閱讀這個URL(https://developers.google.com/android/reference/com/google/android/gms/wearable/DataApi)。

MessageApi:它提供的API供組件將消息發(fā)送到其他節(jié)點。消息通常應該包含小型有效數(shù)據(jù)。你應使用Assets與 DataApi來存儲大數(shù)據(jù)。有關(guān)細節(jié),請閱讀這個URL(https://developers.google.com/android/reference/com/google/android/gms/wearable/MessageApi)。

在下面提供的這個特別的演示例程中,我要使用DataApi來發(fā)送/同步設(shè)備之間的數(shù)據(jù)。由于DataApi是Google Play Services的一部分,那么我們需要做的第一件事是添加以下命名空間引用:

  1. using Android.Gms.Common.Apis; 
  2.  
  3. using Android.Gms.Wearable; 

Android.Gms.Common.Apis允許我們使用GoogleApiClient,這是集成Google Play Services的主入口點。Android.Gms.Wearable使我們能夠使用WearableClass類。下一步是要擴展我們的MainActivity類,即需要繼承以下接口:

1. IDataApiDataListener

2. IGoogleApiClientConnectionCallbacks

3. IGoogleApiClientOnConnectionFailedListener

IDataApiDataListener用來接收數(shù)據(jù)事件。IGoogleApiClientConnectionCallbacks接口提供的回調(diào)函數(shù)在客戶端連接或斷開服務(wù)時調(diào)用。IGoogleApiClientOnConnectionFailedListener接口提供的回調(diào)函數(shù)在客戶端連接到服務(wù)失敗時調(diào)用。

概括一下,將數(shù)據(jù)發(fā)送到手持設(shè)備的示例代碼歸納如下:

  1. using System; 
  2.  
  3. using Android.Runtime; 
  4.  
  5. using Android.Widget; 
  6.  
  7. using Android.OS; 
  8.  
  9. using Android.Support.Wearable.Views; 
  10.  
  11. using Java.Interop; 
  12.  
  13. using Android.Gms.Common.Apis; 
  14.  
  15. using Android.Gms.Wearable; 
  16.  
  17. using System.Linq; 
  18.  
  19. namespace WearDemo 
  20.  
  21.  
  22. [Activity(Label = "WearDemo", MainLauncher = true, Icon = "@drawable/icon")] 
  23.  
  24. public class MainActivity : Activity,IDataApiDataListener, IGoogleApiClientConnectionCallbacks, IGoogleApiClientOnConnectionFailedListener 
  25.  
  26.  
  27. private IGoogleApiClient _client; 
  28.  
  29. const string _syncPath = "/WearDemo/Data"
  30.  
  31. protected override void OnCreate(Bundle bundle) { 
  32.  
  33. base.OnCreate(bundle); 
  34.  
  35. _client = new GoogleApiClientBuilder(this, this, this) 
  36.  
  37. .AddApi(WearableClass.Api) 
  38.  
  39. .Build(); 
  40.  
  41. // Set our view from the "main" layout resource 
  42.  
  43. SetContentView(Resource.Layout.Main); 
  44.  
  45. var v = FindViewById<WatchViewStub>(Resource.Id.watch_view_stub); 
  46.  
  47. v.LayoutInflated += delegate { 
  48.  
  49. // Get our button from the layout resource, 
  50.  
  51. // and attach an event to it 
  52.  
  53. Button button = FindViewById<Button>(Resource.Id.myButton); 
  54.  
  55. button.Click += delegate { 
  56.  
  57. SendData(); 
  58.  
  59. }; 
  60.  
  61. }; 
  62.  
  63.  
  64. public void SendData() { 
  65.  
  66. try { 
  67.  
  68. var request = PutDataMapRequest.Create(_syncPath); 
  69.  
  70. var map = request.DataMap; 
  71.  
  72. map.PutString("Message""Vinz says Hello from Wearable!"); 
  73.  
  74. map.PutLong("UpdatedAt", DateTime.UtcNow.Ticks); 
  75.  
  76. WearableClass.DataApi.PutDataItem(_client, request.AsPutDataRequest()); 
  77.  
  78.  
  79. finally { 
  80.  
  81. _client.Disconnect(); 
  82.  
  83.  
  84.  
  85. protected override void OnStart() { 
  86.  
  87. base.OnStart(); 
  88.  
  89. _client.Connect(); 
  90.  
  91.  
  92. public void OnConnected(Bundle p0) { 
  93.  
  94. WearableClass.DataApi.AddListener(_client, this); 
  95.  
  96.  
  97. public void OnConnectionSuspended(int reason) { 
  98.  
  99. Android.Util.Log.Error("GMSonnection suspended " + reason); 
  100.  
  101. WearableClass.DataApi.RemoveListener(_client, this); 
  102.  
  103.  
  104. public void OnConnectionFailed(Android.Gms.Common.ConnectionResult result) { 
  105.  
  106. Android.Util.Log.Error("GMSonnection failed " + result.ErrorCode); 
  107.  
  108.  
  109. protected override void OnStop() { 
  110.  
  111. base.OnStop(); 
  112.  
  113. _client.Disconnect(); 
  114.  
  115.  
  116. public void OnDataChanged(DataEventBuffer dataEvents) { 
  117.  
  118. var dataEvent = Enumerable.Range(0, dataEvents.Count
  119.  
  120. .Select(i => dataEvents.Get(i).JavaCast<IDataEvent) 
  121.  
  122. .FirstOrDefault(x => x.Type == DataEvent.TypeChanged && x.DataItem.Uri.Path.Equals(_syncPath)); 
  123.  
  124. if (dataEvent == null
  125.  
  126. return
  127.  
  128. //do stuffs here 
  129.  
  130.  
  131.  

現(xiàn)在來解釋一下上面代碼中發(fā)生的事情。在OnCreate事件中,我們構(gòu)建了一個Google Play Services客戶端,它包括可穿戴設(shè)備API。然后,我們在按鈕的click事件處理程序中調(diào)用SendData()方法實現(xiàn)數(shù)據(jù)發(fā)送。其中,SendData()方法包含發(fā)送數(shù)據(jù)的實際邏輯。具體實現(xiàn)中,我們通過傳遞數(shù)據(jù)對象路徑(即WearDemo/Data)創(chuàng)建了一個DataMapRequest請求。實際的數(shù)據(jù)是DataMap,其中包含了一個Message值和一個UpdatedAt值。接收方可以使用路徑來確定本文中稍后要介紹的數(shù)據(jù)來源。

事件

1.OnStart:當活動啟動時觸發(fā)此事件,用于連接到數(shù)據(jù)層。

2.OnConnected:當數(shù)據(jù)層的連接成功時觸發(fā)此事件。

3.OnStop:斷開數(shù)據(jù)層連接時觸發(fā)此事件,此時活動停止 。你可以使用OnConnectionSuspended和OnConnectionFailed來實現(xiàn)對應的連接回調(diào)(例如在本演示中我們記錄錯誤及分離服務(wù))。

4.OnDataChanged:當數(shù)據(jù)更改時觸發(fā)此事件。

需要牢記的事情

1.路徑應該總是以正斜線(/)字符開頭。

2.時間戳是發(fā)送數(shù)據(jù)時必須使用的,因為OnDataChanged()事件僅在數(shù)據(jù)真正更改時觸發(fā)。將時間戳添加到數(shù)據(jù)將確保調(diào)用了該方法。

在文件AndroidManifest.xml的<application>元素下添加下列元數(shù)據(jù):

  1. <meta-data android:name="com.google.android.gms.version" 
  2.  
  3. android:value="@integer/google_play_services_version" /> 

創(chuàng)建主程序項目

為了測試同步和數(shù)據(jù)發(fā)送,我們需要創(chuàng)建一個主安卓應用程序,由它來負責接收來自可穿戴設(shè)備的數(shù)據(jù)對象。其中,這個主程序?qū)惭b在手持設(shè)備(例如手機或平板電腦)中。

現(xiàn)在,右鍵單擊解決方案項目,選擇命令“Add->New Project”。在“Add->New Project”窗口中選擇“Visual C# > Android > Blank App (Android)”。你應該能夠看到如下圖這個樣子:

圖 11: Android主程序項目

為簡單起見,我命名項目為MainAppDemo。此后,只需單擊OK命令讓系統(tǒng)為您生成所需的文件。最終,你在解決方案界面中將看到如圖所示結(jié)果。

圖 12: 解決方案資源管理器

在我們開始將邏輯添加到主應用程序之前,我想突出強調(diào)以下兩點:

第一點:你的可穿戴設(shè)備應用程序和主應用程序的命名空間應該是相同的。在此示例中,可穿戴應用程序使用的命名空間是"WearDemo"。所以,一定要重命名您的主程序的命名空間為"WearDemo",從而使之匹配。若要更改默認的命名空間,您可以參考下列這些步驟:

(1)轉(zhuǎn)到命令“Project->Properties->Default Namespace”。

(2)若要更改其他項,你可以使用CTRL + H快捷鍵把默認命名空間替換為WearDemo。

(3)您也可以使用重構(gòu)代碼技術(shù)來更改命名空間。這只需要用鼠標右鍵單擊命名空間并選擇“Refactor->Rename”命令即可。

第二點:你的可穿戴設(shè)備程序和主應用程序的包名也應該相同。你可以找到該軟件包的名稱,這只需要右鍵單擊該項目并選擇選擇“Properties->Android Manifest”命令,如下面的圖像所示:

圖 13: Android配置文件

請確保這兩個軟件包名稱均被設(shè)置為"WearDemo.WearDemo"。一定要確保兩個項目生成成功。一旦你做完這一步,你就可以繼續(xù)往下操作——開始修改項目了。首先,要將"Compile using Android version"更改為"API Level 21 (Xamarin.Android v5.0 Support) "API。請參考下面的圖片:

圖 14 ︰應用程序設(shè)置

在引用位置,檢查你是否引用了Xamarin.Android.Support.V4。如果沒有這樣做,你也可以右鍵單擊References,然后選擇Manage NUGET Packages。然后,在“Online> Nuget.Org”下搜索"Xamarin.Android.Support.V4"。你應該能夠看到這樣的內(nèi)容:

圖 15: NuGet程序包管理器

只需單擊安裝并等待,直到任務(wù)完成?,F(xiàn)在,你需要做同樣的操作并安裝"Xamarin.Android.Wear-1.0.0"。

添加服務(wù)WearableListenerService

擴展WearableListenerService服務(wù)能夠讓你偵聽數(shù)據(jù)層中的任何更新。由系統(tǒng)來管理服務(wù)的生命周期:當需要發(fā)送數(shù)據(jù)項或消息時實現(xiàn)綁定到服務(wù);而當沒有工作做時實現(xiàn)解除到服務(wù)的綁定。更多細節(jié),請參考這個URL(https://developers.google.com/android/reference/com/google/android/gms/wearable/WearableListenerService)。

此后,我們將使用WearableListenerService來監(jiān)聽從數(shù)據(jù)層發(fā)來的更新事件并處理數(shù)據(jù)。那么,下一步是添加擴展WearableListenerService的類。為此,右鍵單擊項目根目錄并選擇“Add->Class”,然后命名為"WearService"。下面給出此類完整的邏輯實現(xiàn)代碼。

  1. using System.Linq; 
  2.  
  3. using Android.App; 
  4.  
  5. using Android.Content; 
  6.  
  7. using Android.Runtime; 
  8.  
  9. using Android.Gms.Wearable; 
  10.  
  11. using Android.Gms.Common.Apis; 
  12.  
  13. using Android.Support.V4.Content; 
  14.  
  15. namespace WearDemo 
  16.  
  17.  
  18. [Service] 
  19.  
  20. [IntentFilter(new[] { "com.google.android.gms.wearable.BIND_LISTENER" })] 
  21.  
  22. public class WearService : WearableListenerService 
  23.  
  24.  
  25. const string _syncPath = "/WearDemo/Data"
  26.  
  27. IGoogleApiClient _client; 
  28.  
  29. public override void OnCreate() { 
  30.  
  31. base.OnCreate(); 
  32.  
  33. _client = new GoogleApiClientBuilder(this.ApplicationContext) 
  34.  
  35. .AddApi(WearableClass.Api) 
  36.  
  37. .Build(); 
  38.  
  39. _client.Connect(); 
  40.  
  41. Android.Util.Log.Info("WearIntegrationreated"); 
  42.  
  43.  
  44. public override void OnDataChanged(DataEventBuffer dataEvents) { 
  45.  
  46. var dataEvent = Enumerable.Range(0, dataEvents.Count
  47.  
  48. .Select(i => dataEvents.Get(i).JavaCast<IDataEvent) 
  49.  
  50. .FirstOrDefault(x => x.Type == DataEvent.TypeChanged && x.DataItem.Uri.Path.Equals(_syncPath)); 
  51.  
  52. if (dataEvent == null
  53.  
  54. return
  55.  
  56. //get data from wearable 
  57.  
  58. var dataMapItem = DataMapItem.FromDataItem(dataEvent.DataItem); 
  59.  
  60. var map = dataMapItem.DataMap; 
  61.  
  62. string message = dataMapItem.DataMap.GetString("Message"); 
  63.  
  64. Intent intent = new Intent(); 
  65.  
  66. intent.SetAction(Intent.ActionSend); 
  67.  
  68. intent.PutExtra("WearMessage", message); 
  69.  
  70. LocalBroadcastManager.GetInstance(this).SendBroadcast(intent); 
  71.  
  72.  
  73.  

上面的代碼實現(xiàn)了OnDataChanged事件,此事件負責過濾從"TypeChanged"事件發(fā)來的數(shù)據(jù)事件。具體地講,它會檢查"/ WearDemo /Data"這個數(shù)據(jù)對象路徑,然后在本地進行廣播。

創(chuàng)建主Activity

下面給出的是主Activity的代碼部分:

  1. using Android.App;   
  2. using Android.Content;   
  3. using Android.Widget;   
  4. using Android.OS;   
  5. using Android.Support.V4.Content;   
  6.    
  7. namespace WearDemo   
  8. {   
  9.     [Activity(Label = "MainAppDemo", MainLauncher = true, Icon = "@drawable/icon")]   
  10.     public class MainActivity : Activity   
  11.     {   
  12.         TextView _txtMsg;   
  13.    
  14.         protected override void OnCreate(Bundle bundle) {   
  15.             base.OnCreate(bundle);   
  16.    
  17.             // Set our view from the "main" layout resource   
  18.             SetContentView(Resource.Layout.Main);   
  19.    
  20.             // Get our TextBox from the layout resource,   
  21.             _txtMsg = FindViewById<TextView>(Resource.Id.txtMessage);   
  22.    
  23.    
  24.             IntentFilter filter = new IntentFilter(Intent.ActionSend);   
  25.             MessageReciever receiver = new MessageReciever(this);   
  26.             LocalBroadcastManager.GetInstance(this).RegisterReceiver(receiver, filter);   
  27.         }   
  28.    
  29.         public void ProcessMessage(Intent intent) {   
  30.             _txtMsg.Text = intent.GetStringExtra("WearMessage");   
  31.         }   
  32.    
  33.         internal class MessageReciever : BroadcastReceiver   
  34.         {   
  35.             MainActivity _main;   
  36.             public MessageReciever(MainActivity owner) { this._main = owner; }   
  37.             public override void OnReceive(Context context, Intent intent) {   
  38.                 _main.ProcessMessage(intent);   
  39.             }   
  40.         }   
  41.     }   

在上面的代碼中,我們進行了注冊,以便在OnCreate()事件中接收來自于ListenerService的廣播消息,然后定義了一個繼承自BroadcastReceiver類的嵌套類,實現(xiàn)了OnReceive()方法并提取有關(guān)數(shù)據(jù)。最后,Process()方法負責處理顯示數(shù)據(jù)到UI的問題。

布局

打開文件Main.xaml,并使用如下內(nèi)容替換原來內(nèi)容:

  1. <?xml version="1.0" encoding="utf-8"?> 
  2.  
  3. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  4.  
  5. android:orientation="vertical" 
  6.  
  7. android:layout_width="fill_parent" 
  8.  
  9. android:layout_height="fill_parent"
  10.  
  11. <TextView 
  12.  
  13. android:id="@+id/txtMessage" 
  14.  
  15. android:layout_width="fill_parent" 
  16.  
  17. android:layout_height="wrap_content" 
  18.  
  19. android:layout_marginTop="50dp" 
  20.  
  21. android:gravity="center" 
  22.  
  23. android:textColor="@android:color/white" 
  24.  
  25. android:textSize="80sp" /> 
  26.  
  27. </LinearLayout> 

上面的標記中沒有什么特別的內(nèi)容。歸納來看,主要是包含了一個用于顯示消息的文本框。

添加Google Play服務(wù)所需要的元數(shù)據(jù)

最后,我們在配置文件AndroidManifest.xml下的 <application>元素中添加元數(shù)據(jù),代碼如下:

  1. <meta-data android:name="com.google.android.gms.version" 
  2.  
  3. android:value="@integer/google_play_services_version" /> 

接下來,我要介紹如何把每一個應用程序部署到每一臺設(shè)備并進行結(jié)果測試。

測試、調(diào)試與部署程序

在本節(jié)中,我們將學習如何在實際設(shè)備中部署和測試應用程序。首先需要說明的是,我使用Nexus 9和LG G Watch作為我的測試設(shè)備。

在我們開始之前,請確保在您的機器上為安卓系統(tǒng)安裝了USB驅(qū)動程序。您可以通過右鍵單擊命令“Computer > Manage > Device Manager > Other Devices”進行驗證。如果驅(qū)動程序不在列表中,那么你必須先下載驅(qū)動程序(參考這個地址:http://developer.android.com/sdk/win-usb.htmland)并進行安裝(安裝方法請參閱鏈接: http://developer.android.com/tools/extras/oem-usb.html#InstallingDriver)。

接下來一個重要的事情是,在您的手持設(shè)備中啟用USB調(diào)試。您可以使用命令“Settings > Developer Options > Usb Debugging”啟用此功能。一旦你安裝了必需的驅(qū)動程序并啟用了您的設(shè)備的調(diào)試支持,那么你只需將您的手持設(shè)備插入您的PC或筆記本電腦即可。在Visual Studio中,你應該能夠看到所連接的手持設(shè)備顯示如下圖所示:

圖16: 接通手持設(shè)備后的項目界面

把主程序部署到手持設(shè)備

以下是部署主應用程序的主要步驟:

(1)右鍵單擊主應用程序項目并選擇“Properties > Android Options”選項。然后,在Packaging選項卡下取消選中" Use Fast Deployment (debug mode only)"。

(2)卸載項目。

(3)編輯.csproj文件并在其中添加PropertyGroup部分:

  1. <PropertyGroup> 
  2.  
  3. <JavaMaximumHeapSize>1G</JavaMaximumHeapSize> 
  4.  
  5. </PropertyGroup> 

(4)保存文件,然后加載該項目。

(5)右鍵單擊主應用程序項目并將其設(shè)置為啟動項目。

(6)構(gòu)建應用程序。

(7)單擊運行或播放按鈕。系統(tǒng)將開始打包并將應用程序安裝到設(shè)備上。只需稍等一會兒就會完成。

部署可穿戴設(shè)備應用程序

您可以按照如上面同樣的過程來部署可穿戴應用程序。不過,如果你想要通過藍牙來部署和調(diào)試您的應用程序的話,還需要如下一些額外的步驟:

1) 在您的手持設(shè)備中打開Android Wear關(guān)聯(lián)程序。

2) 從右上角的菜單中選擇Settings。

3) 啟用"Debugging Over Bluetooth"。你應該能夠看到像下面這樣的輸出狀態(tài):

Host: disconnected

Target: connected

4) 把掌上電腦通過USB連接到您的PC或筆記本電腦。

5) 在Visual Studio中,轉(zhuǎn)到“Tools > Android > Android Adb Command Prompt”處,運行以下命令:

adb forward tcp:4444 localabstract:/adb-hub

adb connect localhost:4444

6) 然后,你應該能夠看到可穿戴設(shè)備顯示在設(shè)備列表中,如下面的圖像所示:

圖17:顯示連接成功的設(shè)備

7) 重復與上面步驟1- 5相同的步驟,把主程序部署到手持設(shè)備。

8) 現(xiàn)在,設(shè)置你的可穿戴設(shè)備應用程序為啟動項目,構(gòu)建應用程序并運行起來。

一旦安裝結(jié)束,你應該能夠在Visual Studio 設(shè)置斷點開始調(diào)試和測試您的應用程序。下面是示例應用程序的輸出結(jié)果:

圖18:最終的輸出結(jié)果

最后,你可以從Github下載本文示范項目源碼,供您學習參考。

小結(jié)

在這篇文章中,你已經(jīng)學習了下列內(nèi)容:

1.大概了解了可穿戴設(shè)備和安卓系統(tǒng)

2.設(shè)置開發(fā)環(huán)境

3.創(chuàng)建一個簡單的Android可穿戴設(shè)備應用程序

4.創(chuàng)建了一個應用程序,它能夠保持可穿戴設(shè)備和Android手持設(shè)備之間的數(shù)據(jù)同步

5.測試、調(diào)試和部署橫跨可穿戴設(shè)備和手持設(shè)備的Android應用程序。

責任編輯:趙立京 來源: 51CTO
相關(guān)推薦

2021-02-03 00:18:05

可穿戴設(shè)備醫(yī)療應用物聯(lián)網(wǎng)

2024-05-09 10:28:09

IIoT可穿戴設(shè)備工業(yè)物聯(lián)網(wǎng)

2014-11-12 13:37:57

可穿戴設(shè)備英特爾

2014-05-05 11:02:02

2015-06-16 17:15:39

無線技術(shù)可穿戴設(shè)備

2020-02-25 16:48:11

物聯(lián)網(wǎng)可穿戴設(shè)備智能眼鏡

2018-11-16 09:00:05

可穿戴設(shè)備智能測試

2021-11-22 21:59:47

物聯(lián)網(wǎng)醫(yī)學可穿戴設(shè)備

2013-08-23 10:45:30

可穿戴設(shè)備

2015-10-22 11:08:19

2021-03-16 11:24:53

物聯(lián)網(wǎng)可穿戴設(shè)備IOT

2013-08-19 09:05:31

大數(shù)據(jù)

2015-10-20 15:31:23

可穿戴設(shè)備物聯(lián)網(wǎng)

2024-03-12 09:08:36

可穿戴技術(shù)人工智能

2014-04-24 09:42:06

樂跑手環(huán)運動手環(huán)健康手環(huán)

2014-02-17 09:15:20

MWC可穿戴設(shè)備

2014-07-03 14:38:50

2014-05-20 17:04:08

智能硬件可穿戴設(shè)備反面教材

2015-01-05 09:56:20

可穿戴設(shè)備

2015-08-27 10:42:00

可穿戴設(shè)備無線技術(shù)
點贊
收藏

51CTO技術(shù)棧公眾號