1

一定期間の駐車券を購入できるAndroidモバイルアプリがあります。現在、Android ウェアとの統合を計画しています。

ここで行っていることは次のとおりです。

  1. チケットの有効期限が切れる 15 日前にユーザーに通知するようにします。
  2. これを行うには、ローカル通知を作成し、Alarm Manger を使用してスケジュールします。
  3. このスケジュールされた通知は、Android ブロードキャスト レシーバーによって受信され、この通知がモバイル デバイスの Android 通知セクションに表示されます。
  4. さらに、このレシーバーはインテント サービスを呼び出して、wear に通知を送信します。このステップでは、googleApiClient と onConnected コールバックを作成し、データを送信して通知を表示します。
  5. 装着すると通知を確認でき、タップすると購入したチケットの時間を延長できます。このフローには、通知タップ後の 3 ~ 4 回のビューが含まれます。

ステップ 4 で問題が発生しました。ほとんどの場合、最初の接続 (通知) では Wear は通知を表示せず、2 回目の接続 (通知) では Wear は最初と 2 番目の通知の両方を表示し、その後は正常に動作します。

私たちは問題を解明しようとしましたが、成功しませんでした。以下は、理解のためのレシーバー、インテント サービス、およびウェア側のリストナー サービスのコード スニペットです。

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);
}
4

1 に答える 1

0

アプリのインストール時にダミーのリクエストを送信して解決しました。アプリがインストールされ、その最初のリクエストを食べることによって摩耗で処理されると、これが私の問題を解決しました。:)

于 2015-04-03T17:05:30.100 に答える