|
@ -17,7 +17,6 @@ import com.google.common.util.concurrent.Futures; |
|
|
import com.google.common.util.concurrent.ListenableFuture; |
|
|
import com.google.common.util.concurrent.ListenableFuture; |
|
|
|
|
|
|
|
|
import java.io.File; |
|
|
import java.io.File; |
|
|
import java.io.FileNotFoundException; |
|
|
|
|
|
import java.io.FileOutputStream; |
|
|
import java.io.FileOutputStream; |
|
|
import java.io.IOException; |
|
|
import java.io.IOException; |
|
|
import java.io.InputStream; |
|
|
import java.io.InputStream; |
|
@ -243,14 +242,16 @@ public final class BitmapUtils { |
|
|
* @return dimensions of the image |
|
|
* @return dimensions of the image |
|
|
*/ |
|
|
*/ |
|
|
public static Pair<Integer, Integer> decodeDimensions(@NonNull final ContentResolver contentResolver, |
|
|
public static Pair<Integer, Integer> decodeDimensions(@NonNull final ContentResolver contentResolver, |
|
|
@NonNull final Uri uri) throws FileNotFoundException { |
|
|
|
|
|
|
|
|
@NonNull final Uri uri) throws IOException { |
|
|
BitmapFactory.Options options = new BitmapFactory.Options(); |
|
|
BitmapFactory.Options options = new BitmapFactory.Options(); |
|
|
options.inJustDecodeBounds = true; |
|
|
options.inJustDecodeBounds = true; |
|
|
BitmapFactory.decodeStream(contentResolver.openInputStream(uri), null, options); |
|
|
|
|
|
|
|
|
try (final InputStream stream = contentResolver.openInputStream(uri)) { |
|
|
|
|
|
BitmapFactory.decodeStream(stream, null, options); |
|
|
return (options.outWidth == -1 || options.outHeight == -1) |
|
|
return (options.outWidth == -1 || options.outHeight == -1) |
|
|
? null |
|
|
? null |
|
|
: new Pair<>(options.outWidth, options.outHeight); |
|
|
: new Pair<>(options.outWidth, options.outHeight); |
|
|
} |
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
public static File convertToJpegAndSaveToFile(@NonNull final Bitmap bitmap, @Nullable final File file) throws IOException { |
|
|
public static File convertToJpegAndSaveToFile(@NonNull final Bitmap bitmap, @Nullable final File file) throws IOException { |
|
|
File tempFile = file; |
|
|
File tempFile = file; |
|
|