環境
Windows 10 pro
Android Studio : 最新バージョン
エミュレーター : Android Studioに付属の Wear OS SQUARE API26 (x86)
スマートフォン : Zenfone 2 laser (6.0.1)
エミュレーターとスマートフォンは、このサイトの通りに接続している(bluetoothデバッグはOFF)。Watch Face?をスマホで変更したらスマートウォッチ側でも変更されたので接続は正常
質問内容
以下のやりたいことをする上で以下の問題が発生したので、解決方法を知りたいです
よろしくお願いします
やりたいこと
最終的には、スマートウォッチとスマートフォン両方でデータを同期しようとしています。
その前段階として、スマートフォン側でボタンを押すとcountという変数の値が+1され、countの値をスマートウォッチで表示するということに挑戦中です。
発生している問題・エラーメッセージ
エラーメッセージ
該当のソースコード
スマートフォン側のソースコード
import系は抜いています
java
1public class MainActivity extends Activity implements DataClient.OnDataChangedListener { 2 private DataClient mDataClient; 3 private static final String TAG = "MainActivity"; 4 private static final String DATA_PATH = "/data"; 5 private static final String DATA_KEY = "data"; 6 private int count = 0; 7 8 @Override 9 protected void onCreate(Bundle savedInstanceState) { 10 super.onCreate(savedInstanceState); 11 setContentView(R.layout.activity_main); 12 13 Button btClick = findViewById(R.id.btSend); 14 btSendListener listener = new btSendListener(); 15 btClick.setOnClickListener(listener); 16 } 17 18 private class btSendListener implements View.OnClickListener { 19 @Override 20 public void onClick(View view) { 21 TextView output = findViewById(R.id.tvResult); 22 output.setText("送信中"); 23 24 PutDataMapRequest dataMap = PutDataMapRequest.create(DATA_PATH); 25 dataMap.getDataMap().putInt(DATA_KEY, count); 26 27 PutDataRequest putDataReq =dataMap.asPutDataRequest(); 28 putDataReq.setUrgent(); 29 Task<DataItem> dataItemTask = 30 Wearable.getDataClient(getApplicationContext()).putDataItem(putDataReq); 31 32// try { 33// DataItem dataItem = Tasks.await(dataItemTask); 34// } catch (ExecutionException e) { 35// e.printStackTrace(); 36// } catch (InterruptedException e) { 37// e.printStackTrace(); 38// } 39 40 output.setText(Integer.toString(count)); 41 42 count++; 43 } 44 } 45 46 @Override 47 protected void onResume() { 48 super.onResume(); 49 Wearable.getDataClient(this).addListener(this); 50 } 51 52 @Override 53 protected void onPause() { 54 super.onPause(); 55 Wearable.getDataClient(this).removeListener(this); 56 } 57 58 @Override 59 public void onDataChanged(DataEventBuffer dataEvents) { 60 for(DataEvent event : dataEvents) { 61 if(event.getType() == DataEvent.TYPE_CHANGED) { 62 //DataItem Changed 63 DataItem item = event.getDataItem(); 64 if (item.getUri().getPath().compareTo(DATA_PATH) == 0) { 65 DataMap dataMap = DataMapItem.fromDataItem(item).getDataMap(); 66 updateCount(dataMap.getInt(DATA_KEY)); 67 } 68 } 69 else if(event.getType() == DataEvent.TYPE_DELETED) { 70 //DataItem deleted 71 } 72 } 73 } 74 75 private void updateCount(int c) { 76 TextView tv = findViewById(R.id.tvReceive); 77 tv.setText(Integer.toString(c)); 78 } 79 80// @Override 81 public void onConnected(Bundle bundle) { 82// super.onConnected(); 83 TextView tv = findViewById(R.id.tvStatus); 84 tv.setText("Connected!"); 85 } 86 87// @Override 88 public void onConnectionFailed(Bundle bundle) { 89// super.onConnectionFailed(); 90 TextView tv = findViewById(R.id.tvStatus); 91 tv.setText("Connection Failed"); 92 } 93 94} 95
java
1package com.websarva.wings.android.wearbygoogle2; 2 3import android.os.Bundle; 4import android.support.wearable.activity.WearableActivity; 5import android.view.View; 6import android.widget.TextView; 7 8import com.google.android.gms.wearable.DataClient; 9import com.google.android.gms.wearable.DataEvent; 10import com.google.android.gms.wearable.DataEventBuffer; 11import com.google.android.gms.wearable.DataItem; 12import com.google.android.gms.wearable.DataMap; 13import com.google.android.gms.wearable.DataMapItem; 14import com.google.android.gms.wearable.Wearable; 15 16public class MainActivity extends WearableActivity implements DataClient.OnDataChangedListener { 17 18 private TextView mTextView; 19 private static final String KEY = "data"; 20 private static final String PATH = "/data"; 21 private int count = 0; 22 23 @Override 24 protected void onCreate(Bundle savedInstanceState) { 25 super.onCreate(savedInstanceState); 26 setContentView(R.layout.activity_main); 27 28 mTextView = (TextView) findViewById(R.id.text); 29 mTextView.setText(Integer.toString(0)); 30 // Enables Always-on 31 setAmbientEnabled(); 32 } 33 34 @Override 35 protected void onResume() { 36 super.onResume(); 37 Wearable.getDataClient(this).addListener(this); 38 } 39 40 @Override 41 protected void onPause() { 42 super.onPause(); 43 Wearable.getDataClient(this).removeListener(this); 44 } 45 46 @Override 47 public void onDataChanged(DataEventBuffer dataEvents) { 48 for(DataEvent event : dataEvents) { 49 if(event.getType() == DataEvent.TYPE_CHANGED) { 50 //DataItem Changed 51 DataItem item = event.getDataItem(); 52 if (item.getUri().getPath().compareTo(PATH) == 0) { 53 DataMap dataMap = DataMapItem.fromDataItem(item).getDataMap(); 54 updateCount(dataMap.getInt(KEY)); 55 } 56 } 57 else if(event.getType() == DataEvent.TYPE_DELETED) { 58 //DataItem deleted 59 } 60 } 61 } 62 63 private void updateCount(int c) { 64 mTextView.setText(Integer.toString(c)); 65 } 66 67} 68
試したこと
スマートフォン側のソースコードの通り、スマホでdata layer?に書き込んで、スマホがdata layerに変更があった場合、それを表示するところまではうまく動作しました
つまり、スマホからスマートウォッチへのデータの送信?がうまくいっていないものと思われます
また、スマートフォン側のソースコードで、コメントアウトしているtry-catch文を、戻して実行すると、コメントアウトされた行が実行された時点でアプリが強制終了します。
備考
C言語はかなり詳しいことまで知っていますが、Javaはクラスとメソッドなど簡単なモノしか知りません。
期限の関係でJavaを理解する時間がないので、基本的にはサンプルコードを組み合わせてしていきます。
なので、基本的なことを勉強してから来い!というお言葉はもっともなのですが、現状それができないので、そのようなお言葉は遠慮していただけるとありがたいです。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。