mirror of
https://github.com/M66B/FairEmail.git
synced 2026-04-04 08:08:16 +02:00
Use image decoder for bitmaps
This commit is contained in:
@@ -45,6 +45,7 @@ import android.database.MatrixCursor;
|
||||
import android.graphics.Bitmap;
|
||||
import android.graphics.BitmapFactory;
|
||||
import android.graphics.Color;
|
||||
import android.graphics.ImageDecoder;
|
||||
import android.graphics.Matrix;
|
||||
import android.graphics.Typeface;
|
||||
import android.graphics.drawable.Drawable;
|
||||
@@ -2677,6 +2678,7 @@ public class FragmentCompose extends FragmentBase {
|
||||
args.putParcelableArrayList("uris", new ArrayList<>(uris));
|
||||
args.putBoolean("image", image);
|
||||
args.putInt("resize", resize);
|
||||
args.putInt("zoom", zoom);
|
||||
args.putBoolean("privacy", privacy);
|
||||
args.putCharSequence("body", etBody.getText());
|
||||
args.putInt("start", etBody.getSelectionStart());
|
||||
@@ -2688,6 +2690,7 @@ public class FragmentCompose extends FragmentBase {
|
||||
List<Uri> uris = args.getParcelableArrayList("uris");
|
||||
boolean image = args.getBoolean("image");
|
||||
int resize = args.getInt("resize");
|
||||
int zoom = args.getInt("zoom");
|
||||
boolean privacy = args.getBoolean("privacy");
|
||||
CharSequence body = args.getCharSequence("body");
|
||||
int start = args.getInt("start");
|
||||
@@ -2708,9 +2711,23 @@ public class FragmentCompose extends FragmentBase {
|
||||
File file = attachment.getFile(context);
|
||||
Uri cid = Uri.parse("cid:" + BuildConfig.APPLICATION_ID + "." + attachment.id);
|
||||
|
||||
Drawable d = Drawable.createFromPath(file.getAbsolutePath());
|
||||
if (d == null)
|
||||
throw new IllegalArgumentException(context.getString(R.string.title_no_image));
|
||||
Drawable d;
|
||||
try {
|
||||
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.P) {
|
||||
ImageDecoder.Source source = ImageDecoder.createSource(file.getAbsoluteFile());
|
||||
d = ImageDecoder.decodeDrawable(source);
|
||||
} else
|
||||
d = Drawable.createFromPath(file.getAbsolutePath());
|
||||
} catch (Throwable ex) {
|
||||
Log.w(ex);
|
||||
d = Drawable.createFromPath(file.getAbsolutePath());
|
||||
}
|
||||
|
||||
if (d == null) {
|
||||
int px = Helper.dp2pixels(context, (zoom + 1) * 24);
|
||||
d = context.getDrawable(R.drawable.twotone_broken_image_24);
|
||||
d.setBounds(0, 0, px, px);
|
||||
}
|
||||
|
||||
s.insert(start, "\n\uFFFC\n"); // Object replacement character
|
||||
ImageSpan is = new ImageSpan(context, cid);
|
||||
|
||||
Reference in New Issue
Block a user