0

Android Wear プロジェクトを行っています。通知は でユーザーに表示されるcontentActionので、ユーザーはそれをタップできます。テーピング後、次の API リクエストをキャンセルする時間をユーザーに与えてSomeActivity表示されます。終了 API 呼び出しが行われるDelayedConfirmationViewとき。DelayedConfirmationViewAPI 呼び出しが成功した後ConfirmationActivityが表示されます。ConfirmationActivity返品の際はfinish() SomeActivityキャンセルとさせて頂きます。

私が直面している問題は、SomeActivity が開始された後、理由もなく不思議なことに停止されることです。クラッシュを含むログは次のようになります。

05-20 08:07:49.865 D/My App Wear( 7122): SomeActivity: onCreate
05-20 08:07:49.923 D/My App Wear( 7122): SomeActivity: onStart
05-20 08:07:49.923 D/My App Wear( 7122): SomeActivity: onResume
05-20 08:07:49.991 D/My App( 7122): Google API client connected
05-20 08:07:50.489 D/ViewRootImpl( 7122): changeCanvasOpacity: opaque=true
05-20 08:07:50.492 D/My App Wear( 7122): SomeActivity: onStop
05-20 08:07:53.482 E/My App( 7122): No connection to wearable available!
05-20 08:08:01.689 W/art     ( 7122): Suspending all threads took: 34.878ms
05-20 08:08:01.779 E/ActivityThread( 7122): Performing pause of activity that is not resumed: {SomeActivity}
05-20 08:08:01.779 E/ActivityThread( 7122): java.lang.RuntimeException: Performing pause of activity that is not resumed: {SomeActivity}
05-20 08:08:01.779 E/ActivityThread( 7122):     at android.app.ActivityThread.performPauseActivity(ActivityThread.java:3196)
05-20 08:08:01.779 E/ActivityThread( 7122):     at android.app.ActivityThread.performPauseActivity(ActivityThread.java:3184)
05-20 08:08:01.779 E/ActivityThread( 7122):     at android.app.ActivityThread.handlePauseActivity(ActivityThread.java:3159)
05-20 08:08:01.779 E/ActivityThread( 7122):     at android.app.ActivityThread.access$1000(ActivityThread.java:144)
05-20 08:08:01.779 E/ActivityThread( 7122):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1289)
05-20 08:08:01.779 E/ActivityThread( 7122):     at android.os.Handler.dispatchMessage(Handler.java:102)
05-20 08:08:01.779 E/ActivityThread( 7122):     at android.os.Looper.loop(Looper.java:135)
05-20 08:08:01.779 E/ActivityThread( 7122):     at android.app.ActivityThread.main(ActivityThread.java:5221)
05-20 08:08:01.779 E/ActivityThread( 7122):     at java.lang.reflect.Method.invoke(Native Method)
05-20 08:08:01.779 E/ActivityThread( 7122):     at java.lang.reflect.Method.invoke(Method.java:372)
05-20 08:08:01.779 E/ActivityThread( 7122):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
05-20 08:08:01.779 E/ActivityThread( 7122):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
05-20 08:08:01.779 D/My App Wear( 7122): SomeActivity: onPause
05-20 08:08:01.961 E/ActivityThread( 7122): Performing stop of activity that is not resumed: {SomeActivity}
05-20 08:08:01.961 E/ActivityThread( 7122): java.lang.RuntimeException: Performing stop of activity that is not resumed: {SomeActivity}
05-20 08:08:01.961 E/ActivityThread( 7122):     at android.app.ActivityThread.performStopActivityInner(ActivityThread.java:3309)
05-20 08:08:01.961 E/ActivityThread( 7122):     at android.app.ActivityThread.handleStopActivity(ActivityThread.java:3390)
05-20 08:08:01.961 E/ActivityThread( 7122):     at android.app.ActivityThread.access$1100(ActivityThread.java:144)
05-20 08:08:01.961 E/ActivityThread( 7122):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1307)
05-20 08:08:01.961 E/ActivityThread( 7122):     at android.os.Handler.dispatchMessage(Handler.java:102)
05-20 08:08:01.961 E/ActivityThread( 7122):     at android.os.Looper.loop(Looper.java:135)
05-20 08:08:01.961 E/ActivityThread( 7122):     at android.app.ActivityThread.main(ActivityThread.java:5221)
05-20 08:08:01.961 E/ActivityThread( 7122):     at java.lang.reflect.Method.invoke(Native Method)
05-20 08:08:01.961 E/ActivityThread( 7122):     at java.lang.reflect.Method.invoke(Method.java:372)
05-20 08:08:01.961 E/ActivityThread( 7122):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
05-20 08:08:01.961 E/ActivityThread( 7122):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)

切り取られた通知の作成:

private NotificationCompat.Builder createNotification()
    {    
        NotificationCompat.Action someAction = createSomeAction();

        NotificationCompat.Builder notificationBuilder =
                new NotificationCompat.Builder(this.context)
                        .setSmallIcon(R.drawable.logo)
                        .setLargeIcon(BitmapFactory.decodeResource(
                                this.context.getResources(), R.drawable.logo))
                        .setContentTitle(title)
                        .setContentText(subtitle)
                        .addAction(saveAction)

        NotificationCompat.WearableExtender wearableExtender = new NotificationCompat.WearableExtender()
                .setBackground(BitmapFactory.decodeResource(this.context.getResources(), getRandomBackground()))
                .setContentAction(0)
                .setCustomContentHeight(Utils.dpToPx(100, this.context));

        notificationBuilder.extend(wearableExtender);

        return notificationBuilder;
    }

private NotificationCompat.Action createSaveAction()
    {
        Intent saveIntent = new Intent(this.context, SomeActivity.class);
        PendingIntent savePendingIntent =
                PendingIntent.getActivity(this.context, 3, saveIntent, PendingIntent.FLAG_CANCEL_CURRENT);

        NotificationCompat.Action saveAction =
                new NotificationCompat.Action.Builder(R.drawable.save,
                        this.context.getString(R.string.save), savePendingIntent)
                        .build();

        return saveAction;
    }

一部のアクティビティ:

    public class SomeActivity implements
            DelayedConfirmationView.DelayedConfirmationListener
    {
        private static final int SOME_NOTIFICATION_REQUEST_CODE = 99;
        private DelayedConfirmationView delayedConfirmationView;
        private TextView description;
        private ProgressView progressView;
        private TextView saveLabel;
        protected GoogleApiClient googleApiClient;

        @Override
        public void onCreate(Bundle bundle)
        {
            super.onCreate(bundle);
            setContentView(R.layout.activity_some);
            this.description = (TextView) findViewById(R.id.activity_some_description);
            this.delayedConfirmationView = (DelayedConfirmationView) findViewById(R.id.activity_some_delayed_confirmation);
            this.delayedConfirmationView.setTotalTimeMs(Constants.DELAYED_CONFIRMATION_ANIMATION_TIME_IN_SEC * Constants.MILIS_PER_SECOND);
            this.progressView = (ProgressView)findViewById(R.id.activity_some_progress_view);
            this.someLabel = (TextView)findViewById(R.id.activity_some_label);

            CardScrollView cardScrollView = (CardScrollView) findViewById(R.id.activity_some_card_scroll_view);
            cardScrollView.setCardGravity(Gravity.BOTTOM);

            new GetDataFromDBAsyncTask().execute();
            this.googleApiClient = new GoogleApiClient.Builder(this)
                .addConnectionCallbacks(this)
                .addOnConnectionFailedListener(this)
                .addApi(Wearable.API)
                .build();
        }

        @Override
        protected void onStart()
        {
           super.onStart();
           this.googleApiClient.connect();
        }

        @Override
        protected void onResume()
        {
            super.onResume();
            Handler handler = new Handler();
            handler.postDelayed(new Runnable()
            {
                @Override
                public void run()
                {
                    onStartTimer();
                }
            }, 500);
        }

        @Override
        protected void onPause()
        {
            super.onPause();
            this.delayedConfirmationView.setListener(null);
        }

        @Override
        protected void onStop()
        {
            super.onStop();
            if (null != this.googleApiClient && this.googleApiClient.isConnected())
            {
                Wearable.MessageApi.removeListener(this.googleApiClient, this);
                this.googleApiClient.disconnect();
            }
        }

        @Override
        public void onConnected(Bundle bundle)
        {
            Log.d(Constants.LOG_TAG, "Google API client connected");
            Wearable.MessageApi.addListener(this.googleApiClient, this);
        }

        @Override
        protected void onActivityResult(int requestCode, int resultCode, Intent data)
        {
            super.onActivityResult(requestCode, resultCode, data);

            if (requestCode == SOME_NOTIFICATION_REQUEST_CODE)
            {
                WearableNotificationCenter.getInstance(SomeActivity.this).cancelNotification();
                finish();
            }
        }

        public void onStartTimer()
        {
            this.delayedConfirmationView.setListener(this);
            this.delayedConfirmationView.start();
        }

        @Override
        public void onTimerSelected(View view)
        {
            view.setPressed(true);
            // Prevent onTimerFinished from being heard.
            this.delayedConfirmationView.setListener(null);
            finish();
        }

        @Override
        public void onTimerFinished(View v)
        {
            this.delayedConfirmationView.setEnabled(false);
            this.delayedConfirmationView.setVisibility(View.INVISIBLE);
            this.progressView.setVisibility(View.VISIBLE);
            this.saveLabel.setText(R.string.saving);

            sendApiRequest();
        }

        private void showSaveConfirmation()
        {
            Intent intent = new Intent(this, ConfirmationActivity.class);
            intent.putExtra(ConfirmationActivity.EXTRA_ANIMATION_TYPE,
                    ConfirmationActivity.SUCCESS_ANIMATION);
            intent.putExtra(ConfirmationActivity.EXTRA_MESSAGE,
                    getString(R.string.done));
            startActivityForResult(intent, SOME_NOTIFICATION_REQUEST_CODE);
        }

        private void sendApiRequest()
        {
            some code
        }

        @Override
        public void handleApiResponse(MessageEvent messageEvent)
        {

            showSaveConfirmation();
        }
    }

私はそれを機能させるために多くのことを試みましたが、実際には何も機能しませんでした。何か案は?DelayedConfirmationViewそのような不正行為を引き起こす可能性がありますか?私はネットで例を見ましたが、彼らは でさえそれを開始するonCreateので、それはあり得ません。

私が最も気になるのは、onPause の前に呼び出される onStop があることです。これは非常に奇妙です。で、GoogleApiClient から切断しましたが、アクティビティがまだ有効であるSomeActivityことがわかります。これは、アクティビティが開始されてから 3 秒後に API を呼び出そうとすることがログに示されているためです (3 秒で DelayedConfirmationView が終了します)。問題は、神秘的なものが呼び出されたonStopため、このアクティビティがユーザーに表示されないことです。onStop

4

1 に答える 1

0

最新のOSアップデートで問題が解決したようです。

于 2015-06-17T15:19:45.033 に答える