windowLeak泄漏日志
输入法窗体导致的windowLeak泄漏日志
01-17 20:52:53.706 13312 13312 E WindowManager: android.view.WindowLeaked: Activity com.fadi.onetouchbooster.ui.MainActivity has leaked window androidx.appcompat.app.AppCompatDelegateImpl$ListMenuDecorView{6ea6d53 V.E...... ......I. 0,0-0,0} that was originally added here
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl.<init>(ViewRootImpl.java:828)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl.<init>(ViewRootImpl.java:812)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:389)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:134)
01-17 20:52:53.706 13312 13312 E WindowManager: at androidx.appcompat.app.AppCompatDelegateImpl.openPanel(AppCompatDelegateImpl.java:1576)
01-17 20:52:53.706 13312 13312 E WindowManager: at androidx.appcompat.app.AppCompatDelegateImpl.onKeyUpPanel(AppCompatDelegateImpl.java:1895)
01-17 20:52:53.706 13312 13312 E WindowManager: at androidx.appcompat.app.AppCompatDelegateImpl.onKeyUp(AppCompatDelegateImpl.java:1331)
01-17 20:52:53.706 13312 13312 E WindowManager: at androidx.appcompat.app.AppCompatDelegateImpl.dispatchKeyEvent(AppCompatDelegateImpl.java:1325)
01-17 20:52:53.706 13312 13312 E WindowManager: at androidx.appcompat.app.AppCompatDelegateImpl$AppCompatWindowCallback.dispatchKeyEvent(AppCompatDelegateImpl.java:2813)
01-17 20:52:53.706 13312 13312 E WindowManager: at com.android.internal.policy.DecorView.dispatchKeyEvent(DecorView.java:411)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$ViewPostImeInputStage.processKeyEvent(ViewRootImpl.java:6612)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:6473)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5940)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:5997)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:5963)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:6128)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:5971)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:6185)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5944)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:5997)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:5963)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:5971)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5944)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:5997)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:5963)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:6161)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.ViewRootImpl$ImeInputStage.onFinishedInputEvent(ViewRootImpl.java:6323)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.inputmethod.InputMethodManager$PendingEvent.run(InputMethodManager.java:3158)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.inputmethod.InputMethodManager.invokeFinishedInputEventCallback(InputMethodManager.java:2722)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.inputmethod.InputMethodManager.finishedInputEvent(InputMethodManager.java:2713)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.inputmethod.InputMethodManager$ImeInputEventSender.onInputEventFinished(InputMethodManager.java:3135)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.view.InputEventSender.dispatchInputEventFinished(InputEventSender.java:154)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.os.MessageQueue.nativePollOnce(Native Method)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.os.MessageQueue.next(MessageQueue.java:335)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.os.Looper.loopOnce(Looper.java:169)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.os.Looper.loop(Looper.java:307)
01-17 20:52:53.706 13312 13312 E WindowManager: at android.app.ActivityThread.main(ActivityThread.java:8093)
01-17 20:52:53.706 13312 13312 E WindowManager: at java.lang.reflect.Method.invoke(Native Method)
01-17 20:52:53.706 13312 13312 E WindowManager: at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:579)
01-17 20:52:53.706 13312 13312 E WindowManager: at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1045)
初步解决方案
界面destroy事件时候,执行强制关闭掉输入法对话框显示
private fun hideKeyboard() {
val inputMethodManager = getSystemService(
Activity.INPUT_METHOD_SERVICE) as InputMethodManager?
inputMethodManager?.hideSoftInputFromWindow(currentFocus?.windowToken, 0)
}