I have an application in Play Store. I get NullPointerException everday in my application and I don't know where it come from. Because, logs do not contain any lines from classes i create. Could you please help me to find where it arise from?
java.lang.NullPointerException:
at android.graphics.drawable.AdaptiveIconDrawable.isProjected(AdaptiveIconDrawable.java:551)
at android.view.View.invalidateInternal (View.java:16640)
at android.view.View.invalidate (View.java:16600)
at android.view.View.setFrame (View.java:20945)
at android.widget.ImageView.setFrame (ImageView.java:1208)
at android.view.View.layout (View.java:20838)
at android.widget.LinearLayout.setChildFrame (LinearLayout.java:1791)
at android.widget.LinearLayout.layoutHorizontal (LinearLayout.java:1780)
at android.widget.LinearLayout.onLayout (LinearLayout.java:1546)
at android.view.View.layout (View.java:20841)
at android.view.ViewGroup.layout (ViewGroup.java:6401)
at android.widget.ListView.setupChild (ListView.java:2309)
at android.widget.ListView.makeAndAddView (ListView.java:2202)
at android.widget.ListView.fillDown (ListView.java:824)
at android.widget.ListView.fillGap (ListView.java:788)
at android.widget.AbsListView.trackMotionScroll (AbsListView.java:8184)
at android.widget.ListView.trackMotionScroll (ListView.java:2116)
at android.widget.AbsListView$FlingRunnable.run (AbsListView.java:7607)
at android.view.Choreographer$CallbackRecord.run (Choreographer.java:911)
at android.view.Choreographer.doCallbacks (Choreographer.java:723)
at android.view.Choreographer.doFrame (Choreographer.java:655)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:897)
at android.os.Handler.handleCallback (Handler.java:789)
at android.os.Handler.dispatchMessage (Handler.java:98)
at android.os.Looper.loop (Looper.java:164)
at android.app.ActivityThread.main (ActivityThread.java:6940)
at java.lang.reflect.Method.invoke (Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run (Zygote.java:327)
at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1374)
This is another report. But i think its reason is the same as above.
java.lang.NullPointerException:
at android.graphics.drawable.AdaptiveIconDrawable.isProjected (AdaptiveIconDrawable.java:551)
at android.view.View.invalidateInternal (View.java:16640)
at android.view.View.invalidate (View.java:16600)
at android.view.View.setFrame (View.java:20945)
at android.widget.ImageView.setFrame (ImageView.java:1208)
at android.view.View.layout (View.java:20838)
at android.widget.LinearLayout.setChildFrame (LinearLayout.java:1791)
at android.widget.LinearLayout.layoutHorizontal (LinearLayout.java:1780)
at android.widget.LinearLayout.onLayout (LinearLayout.java:1546)
at android.view.View.layout (View.java:20841)
at android.view.ViewGroup.layout (ViewGroup.java:6401)
at android.widget.ListView.setupChild (ListView.java:2309)
at android.widget.ListView.makeAndAddView (ListView.java:2202)
at android.widget.ListView.fillDown (ListView.java:824)
at android.widget.ListView.fillGap (ListView.java:788)
at android.widget.AbsListView.trackMotionScroll (AbsListView.java:8184)
at android.widget.ListView.trackMotionScroll (ListView.java:2116)
at android.widget.AbsListView.scrollIfNeeded (AbsListView.java:4829)
at android.widget.AbsListView.onTouchMove (AbsListView.java:6523)
at android.widget.AbsListView.onTouchEvent (AbsListView.java:6340)
at android.widget.ListView.onTouchEvent (ListView.java:1700)
at android.view.View.dispatchTouchEvent (View.java:12539)
at android.view.ViewGroup.dispatchTransformedTouchEvent (ViewGroup.java:3153)
at android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:2829)
at android.widget.AbsListView.dispatchTouchEvent (AbsListView.java:6257)
at android.view.ViewGroup.dispatchTransformedTouchEvent (ViewGroup.java:3159)
at android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:2844)
at android.view.ViewGroup.dispatchTransformedTouchEvent (ViewGroup.java:3159)
at android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:2844)
at android.view.ViewGroup.dispatchTransformedTouchEvent (ViewGroup.java:3159)
at android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:2844)
at android.view.ViewGroup.dispatchTransformedTouchEvent (ViewGroup.java:3159)
at android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:2844)
at android.view.ViewGroup.dispatchTransformedTouchEvent (ViewGroup.java:3159)
at android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:2844)
at android.view.ViewGroup.dispatchTransformedTouchEvent (ViewGroup.java:3159)
at android.view.ViewGroup.dispatchTouchEvent (ViewGroup.java:2844)
at com.android.internal.policy.DecorView.superDispatchTouchEvent (DecorView.java:600)
at com.android.internal.policy.PhoneWindow.superDispatchTouchEvent (PhoneWindow.java:1871)
at android.app.Activity.dispatchTouchEvent (Activity.java:3384)
at android.support.v7.view.i.dispatchTouchEvent (WindowCallbackWrapper.java:68)
at com.android.internal.policy.DecorView.dispatchTouchEvent (DecorView.java:562)
at android.view.View.dispatchPointerEvent (View.java:12787)
at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent (ViewRootImpl.java:5615)
at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess (ViewRootImpl.java:5410)
at android.view.ViewRootImpl$InputStage.deliver (ViewRootImpl.java:4903)
at android.view.ViewRootImpl$InputStage.onDeliverToNext (ViewRootImpl.java:4956)
at android.view.ViewRootImpl$InputStage.forward (ViewRootImpl.java:4922)
at android.view.ViewRootImpl$AsyncInputStage.forward (ViewRootImpl.java:5059)
at android.view.ViewRootImpl$InputStage.apply (ViewRootImpl.java:4930)
at android.view.ViewRootImpl$AsyncInputStage.apply (ViewRootImpl.java:5116)
at android.view.ViewRootImpl$InputStage.deliver (ViewRootImpl.java:4903)
at android.view.ViewRootImpl$InputStage.onDeliverToNext (ViewRootImpl.java:4956)
at android.view.ViewRootImpl$InputStage.forward (ViewRootImpl.java:4922)
at android.view.ViewRootImpl$InputStage.apply (ViewRootImpl.java:4930)
at android.view.ViewRootImpl$InputStage.deliver (ViewRootImpl.java:4903)
at android.view.ViewRootImpl.deliverInputEvent (ViewRootImpl.java:7654)
at android.view.ViewRootImpl.doProcessInputEvents (ViewRootImpl.java:7594)
at android.view.ViewRootImpl.enqueueInputEvent (ViewRootImpl.java:7555)
at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent (ViewRootImpl.java:7765)
at android.view.InputEventReceiver.dispatchInputEvent (InputEventReceiver.java:197)
at android.view.InputEventReceiver.nativeConsumeBatchedInputEvents (Native Method)
at android.view.InputEventReceiver.consumeBatchedInputEvents (InputEventReceiver.java:186)
at android.view.ViewRootImpl.doConsumeBatchedInput (ViewRootImpl.java:7728)
at android.view.ViewRootImpl$ConsumeBatchedInputRunnable.run (ViewRootImpl.java:7792)
at android.view.Choreographer$CallbackRecord.run (Choreographer.java:911)
at android.view.Choreographer.doCallbacks (Choreographer.java:723)
at android.view.Choreographer.doFrame (Choreographer.java:652)
at android.view.Choreographer$FrameDisplayEventReceiver.run (Choreographer.java:897)
at android.os.Handler.handleCallback (Handler.java:789)
at android.os.Handler.dispatchMessage (Handler.java:98)
at android.os.Looper.loop (Looper.java:164)
at android.app.ActivityThread.main (ActivityThread.java:6940)
at java.lang.reflect.Method.invoke (Native Method)
at com.android.internal.os.Zygote$MethodAndArgsCaller.run (Zygote.java:327)
at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1374)
And this is my manifest file.
<?xml version="1.0" encoding="utf-8"?>
<manifest
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
package="com.burockgames.timeclocker">
<uses-permissionandroid:name="android.permission.PACKAGE_USAGE_STATS"tools:ignore="ProtectedPermissions"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE"/>
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
<uses-permission android:name="android.permission.VIBRATE"/>
<application
android:allowBackup="true"
android:icon="@mipmap/icon"
android:label="@string/app_name"
android:roundIcon="@mipmap/icon_round"
android:supportsRtl="true"
android:theme="@style/AppTheme"
android:fullBackupContent="false"
android:hardwareAccelerated="false"
android:largeHeap="true"
tools:ignore="GoogleAppIndexingWarning">
<activity
android:name=".main.MainActivity"
android:label="@string/app_name"
android:theme="@style/AppTheme.NoActionBar"
android:screenOrientation="portrait">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity android:name=".applist.AppList"
android:screenOrientation="portrait"/>
(more activities)
<receiver android:name=".service.BroadCastReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
</intent-filter>
</receiver>
<receiver
android:name=".service.AlarmReceiver">
</receiver>
</application>
IMPORTANT: It always happens at Android Oreo (8.0 or 8.1) devices. By the way, I have a method like below. It returns the list of installed applications. Element of list is "MainActivity_App". In method, firsty i get the icon, packagename and name of applications one by one and i create the MainActivity_App by using them. Can the bug occur from this code?
private List<MainActivity_App> getInstalledApps() {
List<MainActivity_App> temp = new ArrayList<>();
List<ApplicationInfo> packs = packageManager.getInstalledApplications(PackageManager.GET_META_DATA);
ArrayList<ApplicationInfo> applistTemp = new ArrayList<>();
for (ApplicationInfo info : packs) {
try {
if (packageManager.getLaunchIntentForPackage(info.packageName) != null) {
applistTemp.add(info);
}
} catch (Exception e) {
e.printStackTrace();
}
}
chosenAppsList=new ArrayList<>();
String s=settings.getString("chosenApps","");
for (int i = 0; i < applistTemp.size(); i++) {
ApplicationInfo info = applistTemp.get(i);
String appPackageName = info.packageName;
String appName="";
Drawable icon=null;
boolean select=false;
if (s.contains(appPackageName)) {
appName = info.loadLabel(getPackageManager()).toString();
icon = info.loadIcon(getPackageManager());
select = true;
}
MainActivity_App newApp=new MainActivity_App(appPackageName, appName, icon, 0, select);
temp.add(newApp);
}
return temp;
}
And there is the MainActivity_App class.
public class MainActivity_App {
private final String appPackageName;
private final String appName;
private final Drawable appIcon;
private long usedTime;
private final boolean isSelected;
MainActivity_App(String packageName, String name, Drawable icon, long time, boolean select) {
appPackageName=packageName;
appName=name;
appIcon=icon;
usedTime=time;
isSelected=select;
}
public String getAppPackageName() {
return appPackageName;
}
String getAppName() {
return appName;
}
Drawable getAppIcon() {
return appIcon;
}
long getUsedTime() {
return usedTime;
}
boolean getIsSelected() {
return isSelected;
}
public void setUsedTime(long usedTime) {
this.usedTime = usedTime;
}
}