close inputstream in image meta data analysers

(cherry picked from commit 358c70828f)
This commit is contained in:
Daniel Gultsch 2021-01-31 10:13:20 +01:00 committed by Christian Schneppe
parent 59a76d5bba
commit 1db9782db8

View file

@ -388,12 +388,12 @@ public class FileBackend {
return result;
}
public boolean useImageAsIs(Uri uri) {
String path = getOriginalPath(uri);
public boolean useImageAsIs(final Uri uri) {
final String path = getOriginalPath(uri);
if (path == null || isPathBlacklisted(path)) {
return false;
}
File file = new File(path);
final File file = new File(path);
long size = file.length();
if ((size == 0 || size >= mXmppConnectionService.getCompressImageSizePreference()) && mXmppConnectionService.getCompressImageSizePreference() != 0) {
return false;
@ -404,12 +404,15 @@ public class FileBackend {
BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true;
try {
BitmapFactory.decodeStream(mXmppConnectionService.getContentResolver().openInputStream(uri), null, options);
final InputStream inputStream = mXmppConnectionService.getContentResolver().openInputStream(uri);
BitmapFactory.decodeStream(inputStream, null, options);
close(inputStream);
if (options.outMimeType == null || options.outHeight <= 0 || options.outWidth <= 0) {
return false;
}
return (options.outWidth <= mXmppConnectionService.getCompressImageResolutionPreference() && options.outHeight <= mXmppConnectionService.getCompressImageResolutionPreference() && options.outMimeType.contains(Config.IMAGE_FORMAT.name().toLowerCase()));
} catch (FileNotFoundException e) {
Log.d(Config.LOGTAG, "unable to get image dimensions", e);
return false;
}
}
@ -620,14 +623,17 @@ public class FileBackend {
updateFileParams(message);
}
public boolean unusualBounds(Uri image) {
public boolean unusualBounds(final Uri image) {
try {
BitmapFactory.Options options = new BitmapFactory.Options();
final BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true;
BitmapFactory.decodeStream(mXmppConnectionService.getContentResolver().openInputStream(image), null, options);
final InputStream inputStream = mXmppConnectionService.getContentResolver().openInputStream(image);
BitmapFactory.decodeStream(inputStream, null, options);
close(inputStream);
float ratio = (float) options.outHeight / options.outWidth;
return ratio > (21.0f / 9.0f) || ratio < (9.0f / 21.0f);
} catch (Exception e) {
} catch (final Exception e) {
Log.w(Config.LOGTAG, "unable to detect image bounds", e);
return false;
}
}
@ -1180,9 +1186,9 @@ public class FileBackend {
}
private int calcSampleSize(Uri image, int size) throws FileNotFoundException, SecurityException {
BitmapFactory.Options options = new BitmapFactory.Options();
final BitmapFactory.Options options = new BitmapFactory.Options();
options.inJustDecodeBounds = true;
InputStream inputStream = mXmppConnectionService.getContentResolver().openInputStream(image);
final InputStream inputStream = mXmppConnectionService.getContentResolver().openInputStream(image);
BitmapFactory.decodeStream(inputStream, null, options);
close(inputStream);
return calcSampleSize(options, size);