onBackPressed иногда или всегда вызывается автоматически при запуске активности - PullRequest
0 голосов
/ 28 февраля 2020

У меня проблема с моим приложением на некоторых устройствах (HUAWEI P10 Lite, rockchip A95XR3). Может быть, больше в будущем.

По словам пользователей, при открытии активности видеоплеера приложение сразу падает.

Я думаю, что, когда они открывают активность видеоплеера, они быстро нажимают кнопку возврата. когда активность не готова. Поэтому я попытался использовать свое устройство Oppo Realme 5Pro, а затем попытался с молниеносной скоростью нажать кнопку «Назад», но оно не достигло sh (пробовал несколько раз). И я также попытался запустить его на эмуляторе в соответствии с версией Android с проблемами 8.0.0 и 9.

Stack Trace:

Fatal Exception: java.lang.NullPointerException: Attempt to invoke virtual method 'void c.d.b.a.t0.b()' on a null object reference
       at com.**cencored**.C_Video_Player.ReleasePlayer(Act_Video_Player.java:163)
       at com.**cencored**.C_Video_Player.onBackPressed(Act_Video_Player.java:405)
       at android.app.Activity.onKeyUp(Activity.java:3161)
       at android.view.KeyEvent.dispatch(KeyEvent.java:2779)
       at androidx.core.view.KeyEventDispatcher.activitySuperDispatchKeyEventPre28(KeyEventDispatcher.java:137)
       at androidx.core.view.KeyEventDispatcher.dispatchKeyEvent(KeyEventDispatcher.java:87)
       at androidx.core.app.ComponentActivity.dispatchKeyEvent(ComponentActivity.java:133)
       at androidx.appcompat.app.AppCompatActivity.dispatchKeyEvent(AppCompatActivity.java:558)
       at androidx.appcompat.view.WindowCallbackWrapper.dispatchKeyEvent(WindowCallbackWrapper.java:59)
       at androidx.appcompat.app.AppCompatDelegateImpl$AppCompatWindowCallback.dispatchKeyEvent(AppCompatDelegateImpl.java:2814)
       at com.android.internal.policy.DecorView.dispatchKeyEvent(DecorView.java:415)
       at android.view.ViewRootImpl$ViewPostImeInputStage.processKeyEvent(ViewRootImpl.java:5191)
       at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:5063)
       at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4581)
       at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:4634)
       at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:4600)
       at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:4727)
       at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:4608)
       at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:4784)
       at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4581)
       at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:4634)
       at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:4600)
       at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:4608)
       at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4581)
       at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:4634)
       at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:4600)
       at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:4760)
       at android.view.ViewRootImpl$ImeInputStage.onFinishedInputEvent(ViewRootImpl.java:4921)
       at android.view.inputmethod.InputMethodManager$PendingEvent.run(InputMethodManager.java:2599)
       at android.view.inputmethod.InputMethodManager.invokeFinishedInputEventCallback(InputMethodManager.java:2160)
       at android.view.inputmethod.InputMethodManager.finishedInputEvent(InputMethodManager.java:2151)
       at android.view.inputmethod.InputMethodManager$ImeInputEventSender.onInputEventFinished(InputMethodManager.java:2574)
       at android.view.InputEventSender.dispatchInputEventFinished(InputEventSender.java:141)
       at android.os.MessageQueue.nativePollOnce(MessageQueue.java)
       at android.os.MessageQueue.next(MessageQueue.java:379)
       at android.os.Looper.loop(Looper.java:144)
       at android.app.ActivityThread.main(ActivityThread.java:7523)
       at java.lang.reflect.Method.invoke(Method.java)
       at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:245)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:921)

Если я вижу Stack Trace через Firebase Crashlytics , похоже, что onBackPressed был вызван, но, по словам пользователя, они не нажимают кнопку возврата.

Ниже приведена часть кода, связанная с проблемой.

private void ReleasePlayer() {
        exoPlayer.release(); //Line 163
        isVideoPrepared ="no";
        TextError.setVisibility(GONE);
        TextReconnecting.setVisibility(GONE);
        TextTryCount.setVisibility(GONE);
    }

@Override
public void onBackPressed() {
        super.onBackPressed();
        exoPlayerView.setVisibility(GONE);
        forInfo.setVisibility(GONE);
        forAds.setVisibility(GONE);
        forControl.setVisibility(GONE);
        ReleasePlayer(); //Line 405
        finish();
   }

На трассе стека выше также не упоминается onCreate, поэтому, конечно, exoplayer еще не инициализирован.

Реальный вопрос в том, каковы проблемы с вышеупомянутыми устройствами? а может в моем коде?

...