Browse Source

Fixing crashes resulting from fragment lifecycle mismanagement

master
anthony restaino 7 years ago
parent
commit
c8a2fd8262
  1. 10
      app/src/main/java/acr/browser/lightning/fragment/BookmarkSettingsFragment.java
  2. 6
      app/src/main/java/acr/browser/lightning/fragment/BookmarksFragment.java
  3. 45
      app/src/main/java/acr/browser/lightning/utils/Utils.java

10
app/src/main/java/acr/browser/lightning/fragment/BookmarkSettingsFragment.java

@ -5,6 +5,7 @@ package acr.browser.lightning.fragment;
import android.Manifest; import android.Manifest;
import android.app.Activity; import android.app.Activity;
import android.app.Application;
import android.app.Dialog; import android.app.Dialog;
import android.content.DialogInterface; import android.content.DialogInterface;
import android.content.pm.ApplicationInfo; import android.content.pm.ApplicationInfo;
@ -61,6 +62,8 @@ public class BookmarkSettingsFragment extends PreferenceFragment implements Pref
@Nullable private Activity mActivity; @Nullable private Activity mActivity;
@Inject BookmarkModel mBookmarkManager; @Inject BookmarkModel mBookmarkManager;
@Inject Application mApplication;
private File[] mFileList; private File[] mFileList;
private String[] mFileNameList; private String[] mFileNameList;
@Nullable private BookmarkLocalSync mSync; @Nullable private BookmarkLocalSync mSync;
@ -454,7 +457,12 @@ public class BookmarkSettingsFragment extends PreferenceFragment implements Pref
@Override @Override
public void onError(@NonNull Throwable throwable) { public void onError(@NonNull Throwable throwable) {
Log.e(TAG, "onError: importing bookmarks", throwable); Log.e(TAG, "onError: importing bookmarks", throwable);
Utils.createInformativeDialog(getActivity(), R.string.title_error, R.string.import_bookmark_error); Activity activity = getActivity();
if (activity != null) {
Utils.createInformativeDialog(activity, R.string.title_error, R.string.import_bookmark_error);
} else {
Utils.showToast(mApplication, R.string.import_bookmark_error);
}
} }
}); });
} }

6
app/src/main/java/acr/browser/lightning/fragment/BookmarksFragment.java

@ -233,12 +233,16 @@ public class BookmarksFragment extends Fragment implements View.OnClickListener,
@Override @Override
public void onItem(@Nullable Boolean item) { public void onItem(@Nullable Boolean item) {
Preconditions.checkNonNull(item); Preconditions.checkNonNull(item);
Activity activity = getActivity();
if (mBookmarkImage == null || activity == null) {
return;
}
if (!item) { if (!item) {
mBookmarkImage.setImageResource(R.drawable.ic_action_star); mBookmarkImage.setImageResource(R.drawable.ic_action_star);
mBookmarkImage.setColorFilter(mIconColor, PorterDuff.Mode.SRC_IN); mBookmarkImage.setColorFilter(mIconColor, PorterDuff.Mode.SRC_IN);
} else { } else {
mBookmarkImage.setImageResource(R.drawable.ic_bookmark); mBookmarkImage.setImageResource(R.drawable.ic_bookmark);
mBookmarkImage.setColorFilter(ThemeUtils.getAccentColor(getContext()), PorterDuff.Mode.SRC_IN); mBookmarkImage.setColorFilter(ThemeUtils.getAccentColor(activity), PorterDuff.Mode.SRC_IN);
} }
} }
}); });

45
app/src/main/java/acr/browser/lightning/utils/Utils.java

@ -34,6 +34,7 @@ import android.util.DisplayMetrics;
import android.util.Log; import android.util.Log;
import android.view.View; import android.view.View;
import android.webkit.URLUtil; import android.webkit.URLUtil;
import android.widget.Toast;
import com.anthonycr.grant.PermissionsManager; import com.anthonycr.grant.PermissionsManager;
import com.anthonycr.grant.PermissionsResultAction; import com.anthonycr.grant.PermissionsResultAction;
@ -75,7 +76,7 @@ public final class Utils {
public static void downloadFile(@NonNull final Activity activity, @NonNull final PreferenceManager manager, final String url, public static void downloadFile(@NonNull final Activity activity, @NonNull final PreferenceManager manager, final String url,
final String userAgent, final String contentDisposition) { final String userAgent, final String contentDisposition) {
PermissionsManager.getInstance().requestPermissionsIfNecessaryForResult(activity, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE, PermissionsManager.getInstance().requestPermissionsIfNecessaryForResult(activity, new String[]{Manifest.permission.READ_EXTERNAL_STORAGE,
Manifest.permission.WRITE_EXTERNAL_STORAGE}, new PermissionsResultAction() { Manifest.permission.WRITE_EXTERNAL_STORAGE}, new PermissionsResultAction() {
@Override @Override
public void onGranted() { public void onGranted() {
String fileName = URLUtil.guessFileName(url, null, null); String fileName = URLUtil.guessFileName(url, null, null);
@ -125,13 +126,13 @@ public final class Utils {
AlertDialog.Builder builder = new AlertDialog.Builder(activity); AlertDialog.Builder builder = new AlertDialog.Builder(activity);
builder.setTitle(title); builder.setTitle(title);
builder.setMessage(message) builder.setMessage(message)
.setCancelable(true) .setCancelable(true)
.setPositiveButton(activity.getResources().getString(R.string.action_ok), .setPositiveButton(activity.getResources().getString(R.string.action_ok),
new DialogInterface.OnClickListener() { new DialogInterface.OnClickListener() {
@Override @Override
public void onClick(DialogInterface dialog, int id) { public void onClick(DialogInterface dialog, int id) {
} }
}); });
AlertDialog alert = builder.create(); AlertDialog alert = builder.create();
alert.show(); alert.show();
BrowserDialog.setDialogSize(activity, alert); BrowserDialog.setDialogSize(activity, alert);
@ -175,6 +176,18 @@ public final class Utils {
Snackbar.make(view, message, Snackbar.LENGTH_SHORT).show(); Snackbar.make(view, message, Snackbar.LENGTH_SHORT).show();
} }
/**
* Shows a toast to the user.
* Should only be used if an activity is
* not available to show a snackbar.
*
* @param context the context needed to show the toast.
* @param resource the string shown by the toast to the user.
*/
public static void showToast(@NonNull Context context, @StringRes int resource) {
Toast.makeText(context, resource, Toast.LENGTH_SHORT).show();
}
/** /**
* Converts Density Pixels (DP) to Pixels (PX). * Converts Density Pixels (DP) to Pixels (PX).
* *
@ -261,7 +274,7 @@ public final class Utils {
int padding = Utils.dpToPx(4); int padding = Utils.dpToPx(4);
Bitmap paddedBitmap = Bitmap.createBitmap(bitmap.getWidth() + padding, bitmap.getHeight() Bitmap paddedBitmap = Bitmap.createBitmap(bitmap.getWidth() + padding, bitmap.getHeight()
+ padding, Bitmap.Config.ARGB_8888); + padding, Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(paddedBitmap); Canvas canvas = new Canvas(paddedBitmap);
canvas.drawARGB(0x00, 0x00, 0x00, 0x00); // this represents white color canvas.drawARGB(0x00, 0x00, 0x00, 0x00); // this represents white color
@ -305,10 +318,10 @@ public final class Utils {
String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date()); String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss").format(new Date());
String imageFileName = "JPEG_" + timeStamp + '_'; String imageFileName = "JPEG_" + timeStamp + '_';
File storageDir = Environment File storageDir = Environment
.getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES); .getExternalStoragePublicDirectory(Environment.DIRECTORY_PICTURES);
return File.createTempFile(imageFileName, /* prefix */ return File.createTempFile(imageFileName, /* prefix */
".jpg", /* suffix */ ".jpg", /* suffix */
storageDir /* directory */ storageDir /* directory */
); );
} }
@ -382,9 +395,9 @@ public final class Utils {
paint.setDither(true); paint.setDither(true);
if (withShader) { if (withShader) {
paint.setShader(new LinearGradient(0, 0.9f * canvas.getHeight(), paint.setShader(new LinearGradient(0, 0.9f * canvas.getHeight(),
0, canvas.getHeight(), 0, canvas.getHeight(),
color, mixTwoColors(Color.BLACK, color, 0.5f), color, mixTwoColors(Color.BLACK, color, 0.5f),
Shader.TileMode.CLAMP)); Shader.TileMode.CLAMP));
} else { } else {
paint.setShader(null); paint.setShader(null);
} }
@ -448,7 +461,7 @@ public final class Utils {
// Calculate the largest inSampleSize value that is a power of 2 and keeps both // Calculate the largest inSampleSize value that is a power of 2 and keeps both
// height and width larger than the requested height and width. // height and width larger than the requested height and width.
while ((halfHeight / inSampleSize) >= reqHeight while ((halfHeight / inSampleSize) >= reqHeight
&& (halfWidth / inSampleSize) >= reqWidth) { && (halfWidth / inSampleSize) >= reqWidth) {
inSampleSize *= 2; inSampleSize *= 2;
} }
} }

Loading…
Cancel
Save