Ciò che la mia app fa è visualizzare una vista sovrapposta del sistema collegata tramite il flag windowManager.addView()
e WindowManager.LayoutParams.TYPE_SYSTEM_OVERLAY
. Questo viene fatto con un servizio, che gestisce la visibilità della vista e alcune altre cose.Non riesco a trovare la causa del mio arresto anomalo con questa traccia dello stack
Tuttavia, sto ricevendo rapporti sugli arresti anomali e non riesco a riprodurli. Inoltre, la traccia dello stack di crash non ha nulla a che fare con il pacchetto della mia app, quindi non posso davvero ottenere la radice di questo problema. Di seguito sono due stacktraces che provengono da fonti diverse, ma sembrano essere correlati:
java.lang.NullPointerException: Attempt to invoke virtual method 'void android.view.View.measure(int, int)' on a null object reference
at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:2388)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2101)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1297)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:7011)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:777)
at android.view.Choreographer.doCallbacks(Choreographer.java:590)
at android.view.Choreographer.doFrame(Choreographer.java:560)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:763)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:6938)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1404)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1199)
.
java.lang.NullPointerException: Attempt to invoke virtual method 'int android.view.View.getMeasuredWidth()' on a null object reference
at android.view.ViewRootImpl.performLayout(ViewRootImpl.java:2484)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2181)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1293)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6599)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:800)
at android.view.Choreographer.doCallbacks(Choreographer.java:603)
at android.view.Choreographer.doFrame(Choreographer.java:572)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:786)
at android.os.Handler.handleCallback(Handler.java:815)
at android.os.Handler.dispatchMessage(Handler.java:104)
at android.os.Looper.loop(Looper.java:194)
at android.app.ActivityThread.main(ActivityThread.java:5616)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:959)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:754)
Sembra che il sistema operativo (ViewRootImpl) sta causando questo problema perché possiede un riferimento null a mio punto di vista. Quindi non riesco a trovare una soluzione per questo.
Sembra che accada su tutte le versioni di Android da 4.4 e la mia app è Proguarded. Queste tracce di stack sono ottenuti da Google Play segnalazioni di crash Negozio
Ecco come io attribuisco al fine di finestra di sistema come una sovrapposizione:
private void attachToSystemWindows(boolean overlayNavigationBar) {
final WindowManager windowManager = (WindowManager) getContext().getSystemService(Context.WINDOW_SERVICE);
final DisplayMetrics metrics = new DisplayMetrics();
windowManager.getDefaultDisplay().getMetrics(metrics);
final boolean isNavBarInBottom = isNavBarInBottom();
final WindowManager.LayoutParams params = new WindowManager.LayoutParams(
calculateWindowWidth(overlayNavigationBar, isNavBarInBottom, metrics, mNavigationBarHeight),
calculateWindowHeight(overlayNavigationBar, isNavBarInBottom, metrics, mNavigationBarHeight),
0,
0,
WindowManager.LayoutParams.TYPE_SYSTEM_OVERLAY,
0x50728,
-3
);
params.gravity = Gravity.TOP;
windowManager.addView(this, params);
}
private boolean isNavBarInBottom() {
final boolean isLargeDevice = getResources().getConfiguration().smallestScreenWidthDp >= 600;
final int orientation = getResources().getConfiguration().orientation;
if (BuildConfig.DEBUG)
Log.d("MeshView", "Is NavBar in bottom: " + (isLargeDevice || orientation == Configuration.ORIENTATION_PORTRAIT));
return isLargeDevice || orientation == Configuration.ORIENTATION_PORTRAIT;
}
E il mio metodo onMeasure:
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec);
if (BuildConfig.DEBUG) Log.d("MeshView", "OnMeasure");
setMeasuredDimension(
Math.max(getSuggestedMinimumWidth(), resolveSize(SIZE_MIN_WIDTH, widthMeasureSpec)),
Math.max(getSuggestedMinimumHeight(), resolveSize(SIZE_MIN_HEIGHT, heightMeasureSpec))
);
}
Può cortesemente dirmi che quale vista si aggiunge qui: windowManager.addView (questo, params); – KishuDroid
@KishuDroid È solo una classe personalizzata che estende View – BamsBamx
@BamsBamx la mia risposta chiarisce il motivo per cui hai ricevuto questo errore? – djodjo