Невозможно вывести данные на износ аэродрома (эмулятор)
Я пытаюсь подтолкнуть данные к эмулятору износа android. Но все напрасно. Мой слушатель на эмуляторе не получает никаких вызовов вообще. Если кто-то еще попробовал работать на изнашивании и толкать данные, пожалуйста, ПОМОГИТЕ.
Это код моего приемника выглядит как
private GoogleApiClient mGoogleApiClient;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_qrcode_generation);
mGoogleApiClient = new GoogleApiClient.Builder(this)
.addApi(Wearable.API)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.build();
final WatchViewStub stub = (WatchViewStub) findViewById(R.id.watch_view_stub);
stub.setOnLayoutInflatedListener(new WatchViewStub.OnLayoutInflatedListener() {
@Override
public void onLayoutInflated(WatchViewStub stub) {
ivQrImage = (ImageView) stub.findViewById(R.id.ivQRImage);
}
});
}
@Override
public void onDataChanged(DataEventBuffer dataEvents) {
for (DataEvent event : dataEvents) {
if (event.getType() == DataEvent.TYPE_CHANGED &&
event.getDataItem().getUri().getPath().equals("/image")) {
final DataMapItem dataMapItem = DataMapItem.fromDataItem(event.getDataItem());
final Asset profileAsset = dataMapItem.getDataMap().getAsset("profileImage");
final Bitmap bitmap = loadBitmapFromAsset(profileAsset);
Log.d(TAG, ""+bitmap);
if (null != bitmap) {
ivQrImage.setImageBitmap(bitmap);
bitmap.recycle();
}
}
}
}
@Override
protected void onStart() {
super.onStart();
mGoogleApiClient.connect();
}
@Override
protected void onStop() {
if (null != mGoogleApiClient && mGoogleApiClient.isConnected()) {
Wearable.DataApi.removeListener(mGoogleApiClient, this);
mGoogleApiClient.disconnect();
}
super.onStop();
}
public Bitmap loadBitmapFromAsset(Asset asset) {
if (asset == null) {
throw new IllegalArgumentException("Asset must be non-null");
}
ConnectionResult result =
mGoogleApiClient.blockingConnect(TIMEOUT_MS, TimeUnit.MILLISECONDS);
if (!result.isSuccess()) {
return null;
}
// convert asset into a file descriptor and block until it ready
InputStream assetInputStream = Wearable.DataApi.getFdForAsset(
mGoogleApiClient, asset).await().getInputStream();
mGoogleApiClient.disconnect();
if (assetInputStream == null) {
Log.w(TAG, "Requested an unknown Asset.");
return null;
}
// decode the stream into a bitmap
return BitmapFactory.decodeStream(assetInputStream);
}
@Override
public void onConnectionFailed(ConnectionResult connectionResult) {
Log.d(TAG,"Connection Failed");
}
@Override
public void onConnected(Bundle bundle) {
Wearable.DataApi.addListener(mGoogleApiClient, this);
Wearable.MessageApi.addListener(mGoogleApiClient, this);
}
Вот как я нажимаю
private void pushImageToWear() {
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.qr_code);
Asset asset = createAssetFromBitmap(bitmap);
PutDataMapRequest dataMap = PutDataMapRequest.create("/image");
dataMap.getDataMap().putAsset("profileImage", asset);
PutDataRequest request = dataMap.asPutDataRequest();
PendingResult<DataApi.DataItemResult> pendingResult = Wearable.DataApi
.putDataItem(mGoogleApiClient, request);
}
У меня также есть следующее в моем манифесте для активности Android Wear
<activity
android:name=".QRCodeReceptionActivity"
android:label="@string/app_name"
android:exported="true"
android:allowEmbedded="true"
android:taskAffinity=""
android:theme="@android:style/Theme.DeviceDefault.Light">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
P.S. Нет ничего экстраординарного, что я делаю. Просто следуйте учебнику, указанному на сайте разработчика.
Ответы
Ответ 1
Извините, что я использую Answer, но мне нужна репутация 50 для комментариев: (
У меня была такая же проблема здесь fooobar.com/questions/331658/..., но теперь я ее исправил.
Хорошо, я разделяю с вами все проблемы, с которыми я столкнулся:
Сначала в файлах AndroidManifest.xml на мобильном устройстве добавьте следующее:
<meta-data android:name="com.google.android.gms.version" android:value="@integer/google_play_services_version" />
Во-вторых, что меня немного смутило, что onDataChanged() вызывается только тогда, когда DataItem внутри действительно "изменен". Так что это работает в первый раз, но потом ничего не произойдет.
Я изменил код на мобильном устройстве, поэтому каждый раз, когда я пытаюсь отправить данные, у него есть другая временная метка:
Asset asset = createAssetFromBitmap(bitmap);
PutDataMapRequest request = PutDataMapRequest.create("/image");
DataMap map = request.getDataMap();
map.putLong("time", new Date().getTime()); // MOST IMPORTANT LINE FOR TIMESTAMP
map.putAsset("profileImage", asset);
Wearable.DataApi.putDataItem(mGoogleApiClient, request.asPutDataRequest());
Я узнал в этом IO Video
Остальная часть кода выглядит как ваша.
Я надеюсь, что эта помощь.
Ответ 2
У меня также была эта проблема, и для ее решения потребовалось несколько часов. Моя рекомендация? Создайте новый проект с помощью Android Studio и выберите Android Wear и Phone + Tablet в качестве типов проектов. Это даст вам скелет рабочего проекта, а затем просто перекладывает на ваш существующий проект отличия от автогенерируемого скелета.
Для меня проблема заключалась в следующем:
- В записи
defaultConfig
build, applicationId должен быть одинаковым как для вашего мобильного, так и для мобильного приложения, например:
defaultConfig {
applicationId "com.rukkus.app"
...
}
- Мобильное приложение должно добавить wearApp в качестве зависимости, например:
dependencies {
...
wearApp project(':wear')
}
Дополнительно (и, по общему признанию, я не уверен, что это необходимо), в образцах Google Dev подключается к API Google в onCreate WearableListenerService
(а не в методе onDataChanged
, как иллюстрирует документация). Итак, мой onCreate выглядит так в WearableListenerService
:
@Override
public void onCreate() {
super.onCreate();
// create Google Client
GoogleApiClient googleApiClient = new GoogleApiClient.Builder(this.ctx)
.addOnConnectionFailedListener(new GoogleApiClient.OnConnectionFailedListener() {
@Override
public void onConnectionFailed(ConnectionResult result){
}
})
.addApi(Wearable.API).build();
//connect the client
googleApiClient.connect();
Log.i(TAG, "**creating google API client now**");
}
Это заняло больше времени, чем я хотел бы признать, что работаю, поэтому, надеюсь, это поможет будущему Googler.
Ответ 3
Приложение вашего устройства и носимое приложение должны соответствовать, как указано в его ответе @Bobby. Мне не нужно было носить загружаемое приложение как зависимость.
Ответ 4
Я обнаружил еще одну причину добавления в контрольный список. Носимые и мобильные приложения должны быть созданы с теми же версиями библиотек износа. Проверьте версии в зависимостях gradle.
compile 'com.google.android.support:wearable:1.3.0'
compile 'com.google.android.gms:play-services-wearable:8.1.0'
(у меня недостаточно комментариев для комментариев)