Связь Android Handheld и Wear несовместима

У нас есть мобильное приложение для Android, где вы можете приобрести парковочные талоны на определенный период. Теперь мы планируем интегрировать его с Android Wear.

Что мы делаем здесь:

  1. Мы хотим, чтобы пользователь получил уведомление за 15 до истечения срока действия билета.
  2. Для этого мы создаем локальное уведомление и планируем его с помощью диспетчера тревог.
  3. Это запланированное уведомление получает приемник Android Broadcast и отображает это уведомление на мобильном устройстве в разделе уведомлений Android.
  4. Кроме того, этот получатель вызывает службу намерения, чтобы отправить уведомление об износе. На этом шаге мы создаем googleApiClient и обратный вызов onConnected, мы отправляем данные для износа, чтобы показать уведомление.
  5. При ношении пользователь может проверить уведомление, а при нажатии пользователь может продлить срок действия купленного билета. Этот поток содержит 3-4 просмотра после нажатия на уведомление.

У нас проблема на шаге 4. В большинстве случаев при первом подключении (уведомлении) износ не показывает уведомление, а при втором подключении (уведомлении) износ показывает как первое, так и второе уведомление, и после этого все работает нормально.

Мы пытались разобраться в проблеме, но безуспешно. Ниже приведен фрагмент кода Receiver, Intent Service и ListnerServices на стороне износа для понимания.

public class WearNotificationService extends IntentService {

private static final String TAG = "PhoneActivity";
private GoogleApiClient mGoogleApiClient;
public static String title;
public static String desc;
public static String data;

public WearNotificationService() {
    super("WearNotificationService");
}

@Override
public void onCreate() {
    super.onCreate();
    Toast.makeText(this, title +"--"+ desc , Toast.LENGTH_SHORT).show();
    mGoogleApiClient = new GoogleApiClient.Builder(this).addConnectionCallbacks(new GoogleApiClient.ConnectionCallbacks() {
        @Override
        public void onConnected(Bundle connectionHint) {
            sendNotification(title,desc,data);
            Log.d(TAG, "onConnected: " + connectionHint);
        }

        @Override
        public void onConnectionSuspended(int cause) {
            Log.d(TAG, "onConnectionSuspended: " + cause);
        }
    }).addOnConnectionFailedListener(new GoogleApiClient.OnConnectionFailedListener() {
        @Override
        public void onConnectionFailed(ConnectionResult result) {
            Log.d(TAG, "onConnectionFailed: " + result);
        }
    }).addApi(Wearable.API).build();
    mGoogleApiClient.connect();
}

@Override
protected void onHandleIntent(Intent intent) {
}

private void sendNotification(String title,String desc,String data) {
        Log.e(TAG, "i am onConnectiond: ");
        PutDataMapRequest dataMapRequest = PutDataMapRequest.create(Constants.PATH_NOTIFICATION);
        dataMapRequest.getDataMap().putDouble(Constants.NOTIFICATION_TIMESTAMP, System.currentTimeMillis());
        dataMapRequest.getDataMap().putString(Constants.KEY_TITLE, title);
        dataMapRequest.getDataMap().putString(Constants.KEY_DESC, desc);
        dataMapRequest.getDataMap().putString(Constants.KEY_DATA, data);
        PutDataRequest putDataRequest = dataMapRequest.asPutDataRequest();
        Wearable.DataApi.putDataItem(mGoogleApiClient, putDataRequest);
}

}

@Override
public int onStartCommand(Intent intent, int flags, int startId) {
    if (null != intent) {
        String action = intent.getAction();
        if (Constants.ACTION_DISMISS.equals(action)) {
            dismissNotification();
        }
    }
    return super.onStartCommand(intent, flags, startId);
}

@Override
public void onDataChanged(DataEventBuffer dataEvents) {
    for (DataEvent dataEvent : dataEvents) {
        if (dataEvent.getType() == DataEvent.TYPE_CHANGED) {
            if (Constants.PATH_NOTIFICATION.equals(dataEvent.getDataItem().getUri().getPath())) {
                DataMapItem dataMapItem = DataMapItem.fromDataItem(dataEvent.getDataItem());
                String title = dataMapItem.getDataMap().getString(Constants.KEY_TITLE);
                String content = dataMapItem.getDataMap().getString(Constants.KEY_DESC);
                String data = dataMapItem.getDataMap().getString(Constants.KEY_DATA);
                String id = null;
                try {
                    JSONObject obj = new JSONObject(data);
                     id = (String) obj.get("id");
                } catch (JSONException e) {
                    e.printStackTrace();
                }
                sendNotification(title, content, data,id);
            }
        }
    }
}

private void sendNotification(String title, String content, String data,String id) {
    Intent notificationIntent = new Intent(this, HoursExtension.class);
    Log.e("data1111", data);
    HoursExtension.data = data;
    HoursExtension.id = id;
    PendingIntent notificationPendingIntent = PendingIntent.getActivity(this, 0, notificationIntent,0);

    NotificationCompat.Builder builder = new NotificationCompat.Builder(this)
            .setSmallIcon(R.drawable.icon)
            .setContentTitle(title)
            .setContentText(content)
            .setContentIntent(notificationPendingIntent)
            .extend(new NotificationCompat.WearableExtender().setBackground(BitmapFactory.decodeResource(getResources(), R.drawable.rtabg)))
            ;

    Notification notification = builder.build();

    NotificationManagerCompat notificationManagerCompat = NotificationManagerCompat.from(this);
    notificationManagerCompat.notify(Integer.parseInt(id), notification);
}

person sonilovesh    schedule 02.02.2015    source источник


Ответы (1)


Я решил это, отправив фиктивный запрос на установку приложения. Который отправляется после того, как приложение установлено и обработано изнашиванием, съев этот первый запрос, это решило мою проблему. :)

person sonilovesh    schedule 03.04.2015