Fixed image scaling

pull/198/head
M66B 4 years ago
parent c756e3fd2f
commit efc76a1c63

@ -301,8 +301,7 @@ class ImageHelper {
return d;
} else {
Drawable d = new BitmapDrawable(res, bm);
DisplayMetrics dm = context.getResources().getDisplayMetrics();
d.setBounds(0, 0, Math.round(bm.getWidth() * dm.density), Math.round(bm.getHeight() * dm.density));
d.setBounds(0, 0, bm.getWidth(), bm.getHeight());
if (view != null)
fitDrawable(d, a, scale, view);
return d;
@ -319,9 +318,7 @@ class ImageHelper {
throw new IllegalArgumentException("decode byte array failed");
Drawable d = new BitmapDrawable(context.getResources(), bm);
DisplayMetrics dm = context.getResources().getDisplayMetrics();
d.setBounds(0, 0, Math.round(bm.getWidth() * dm.density), Math.round(bm.getHeight() * dm.density));
d.setBounds(0, 0, bm.getWidth(), bm.getHeight());
if (view != null)
fitDrawable(d, a, scale, view);
@ -338,8 +335,6 @@ class ImageHelper {
Uri uri = Uri.parse(a.source);
Log.i("Loading image source=" + uri);
DisplayMetrics dm = context.getResources().getDisplayMetrics();
BitmapFactory.Options options;
try (InputStream is = context.getContentResolver().openInputStream(uri)) {
options = new BitmapFactory.Options();
@ -347,7 +342,7 @@ class ImageHelper {
BitmapFactory.decodeStream(is, null, options);
}
int scaleToPixels = dm.widthPixels;
int scaleToPixels = res.getDisplayMetrics().widthPixels;
int factor = 1;
while (options.outWidth / factor > scaleToPixels)
factor *= 2;
@ -366,7 +361,7 @@ class ImageHelper {
}
Drawable d = new BitmapDrawable(res, bm);
d.setBounds(0, 0, Math.round(bm.getWidth() * dm.density), Math.round(bm.getHeight() * dm.density));
d.setBounds(0, 0, bm.getWidth(), bm.getHeight());
if (view != null)
fitDrawable(d, a, scale, view);

Loading…
Cancel
Save