android – ExifInterface构造函数抛出IOExxception
作者:互联网
在尝试使用文件路径初始化exif接口实例时,我无法找出ExifInterface构造函数抛出的异常.
更新
请根据要求查看下面的详细代码.
文件下载功能
public void downloadAndSaveFile(String url, String directoryId, String fileName) {
HttpURLConnection conn = null;
try {
Log.d(TAG, "DownloadFileTask url : " + url);
conn = getGETConnection(url);
conn.setRequestProperty("Accept", "application/json");
conn.setRequestProperty("Content-Type", "application/json");
conn.setRequestProperty("Authorization", "Bearer " + MY_AUTH_TOKEN);
conn.connect();
File file = new File(FileTools.getCacheFileLocation(fileName, directoryId));
FileOutputStream fileOutput = new FileOutputStream(file);
InputStream inputStream = (InputStream) conn.getInputStream();
byte[] buffer = new byte[1024 * 1024];
int bufferLength = 0;
while ((bufferLength = inputStream.read(buffer)) > 0) {
fileOutput.write(buffer, 0, bufferLength);
}
fileOutput.close();
inputStream.close();
Log.d(TAG, "Download successful. Downloaded File : " + file.getAbsolutePath());
// Generate thumbnail and encrypt the file and thumbnail
***String thumbnailPath = FileTools.cacheThumbnail(file, file.getName(), directoryId);***
if (thumbnailPath != null && !thumbnailPath.isEmpty()) {
// Encrypt the file
try {
FileTools.SaveFileEncrypted(file, directoryId);
} catch (Exception e) {
e.printStackTrace();
// Delete the file
file.delete();
}
} else {
// Delete the file
file.delete();
}
} catch (Exception e) {
Log.d(TAG, "Exception while downloading file");
e.printStackTrace();
} finally {
if (conn != null) {
conn.disconnect();
}
}
}
FileTools.cacheThumbnail函数
public static String cacheThumbnail(File file, String fileName, String chatId) {
Log.d(TAG, "cacheThumbnail original File path : " + file.getAbsolutePath());
Log.d(TAG, "cacheThumbnail original File exists : " + file.exists());
Log.d(TAG, "cacheThumbnail original file size : " + file.length());
String thumbName = String.format("thumb-%s.jpg", fileName);
File fileThumb = new File(FileTools.getMediaCachePath(chatId), thumbName);
ByteArrayOutputStream out = null;
try {
out = new ByteArrayOutputStream();
BitmapFactory.Options options = new BitmapFactory.Options();
Bitmap image = ThumbnailUtils.extractThumbnail(BitmapFactory.decodeFile(file.toURI().getPath(), options), 256, 256, ThumbnailUtils.OPTIONS_RECYCLE_INPUT);
// Thumbnail generation for the image failed. It is a video file. Generate
// thumbnail for the video file
if (image == null) {
MediaMetadataRetriever retriever = new MediaMetadataRetriever();
try {
retriever.setDataSource(FileTools.getFileInputStreamFromStorage(file).getFD());
// Generate thumbnail from a frame that is 5% deep into the video
String time = retriever.extractMetadata(MediaMetadataRetriever.METADATA_KEY_DURATION);
long timeInMillisec = Long.parseLong(time);
long durationMicroSec = timeInMillisec * 1000;
long thumbnailDepth = (long) (durationMicroSec * (0.15f));
image = retriever.getFrameAtTime(thumbnailDepth, MediaMetadataRetriever.OPTION_CLOSEST);
image = ThumbnailUtils.extractThumbnail(image, 256, 256, ThumbnailUtils.OPTIONS_RECYCLE_INPUT);
} catch (IllegalArgumentException ex) {
Log.e(TAG, ex.getMessage());
image = null;
} catch (RuntimeException ex) {
Log.e(TAG, ex.getMessage());
image = null;
} catch (IOException e) {
image = null;
Log.e(TAG, e.getMessage());
}
}
// Could not generate a thumbnail. Probably a corrupt/bad file
if (image == null) {
return null;
}
***image = Utilities.orientBitmap(file.getAbsolutePath(), image);***
image.compress(Bitmap.CompressFormat.JPEG, 80, out);
out.close();
FileTools.SaveFileEncrypted(fileThumb, out.toByteArray());
return fileThumb.toURI().getPath();
} catch (Exception e) {
e.printStackTrace();
return null;
} finally {
try {
if (out != null) {
out.close();
}
} catch (Exception ignore) {
}
}
}
orientBitmap和rotateBitmap函数功能
public static Bitmap orientBitmap(String filePath, Bitmap bitmap) throws IOException {
Log.d(TAG, "orientBitmap FilePath : " + filePath);
File file = new File(filePath);
Log.d(TAG, "orientBitmap File exists : " + file.exists());
ExifInterface exifInterface = new ExifInterface(filePath);
Log.d(TAG, "After exception");
int orientation = exifInterface.getAttributeInt(ExifInterface.TAG_ORIENTATION, ExifInterface.ORIENTATION_NORMAL);
Log.d(TAG, "Thumb orientation : " + orientation);
switch (orientation) {
case ExifInterface.ORIENTATION_ROTATE_90:
bitmap = rotateBitmap(bitmap, 90);
break;
case ExifInterface.ORIENTATION_ROTATE_180:
bitmap = rotateBitmap(bitmap, 180);
break;
case ExifInterface.ORIENTATION_ROTATE_270:
bitmap = rotateBitmap(bitmap, 270);
break;
}
return bitmap;
}
public static Bitmap rotateBitmap(Bitmap source, float angle) {
Matrix matrix = new Matrix();
matrix.postRotate(angle);
return Bitmap.createBitmap(source, 0, 0, source.getWidth(), source.getHeight(), matrix, true);
}
我在尝试生成mp4文件和png文件的缩略图时通过发布堆栈跟踪来更新堆栈跟踪.
mp4文件的堆栈跟踪.
D/DownloadFileClass: downloadAndSaveFile url : example.com/media/download/568405
D/DownloadFileClass: Download successful. Downloaded File : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/MP4_20161017_134641.mp4
D/FileTools: cacheThumbnail original File path : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/MP4_20161017_134641.mp4
D/FileTools: cacheThumbnail original File exists : true
D/FileTools: cacheThumbnail original file size : 6434816
D/skia: --- SkImageDecoder::Factory returned null
D/Utilities: orientBitmap FilePath : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/MP4_20161017_134641.mp4
D/Utilities: orientBitmap File exists : true
W/ExifInterface: Invalid image.
java.io.IOException: Invalid marker: 0
at android.media.ExifInterface.getJpegAttributes(ExifInterface.java:1600)
at android.media.ExifInterface.loadAttributes(ExifInterface.java:1339)
at android.media.ExifInterface.<init>(ExifInterface.java:1057)
at com.mypackage.helpers.Utilities.orientBitmap(Utilities.java:85)
at com.mypackage.fileio.FileTools.cacheThumbnail(FileTools.java:700)
at com.mypackage.coreapi.DownloadFileClass$downloadAndSaveFile(DownloadFileClass.java:215)
at com.mypackage.coreapi.DownloadFileClass$downloadAndSaveFile(DownloadFileClass.java:113)
at android.os.AsyncTask$2.call(AsyncTask.java:295)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:234)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
at java.lang.Thread.run(Thread.java:818)
D/Utilities: After exception
D/Utilities: Thumb orientation : 0
D/FileTools: Save file to : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/MP4_20161017_134641.mp4
D/EncryptedFileTools: ......Final saved file path...... : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/encryptPlaceHolder
png文件的堆栈跟踪
D/DownloadFileClass: downloadAndSaveFile url : example.com/media/download/568406
D/DownloadFileClass: Download successful. Downloaded File : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/PNG_20161017_134748.png
D/FileTools: cacheThumbnail original File path : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/PNG_20161017_134748.png
D/FileTools: cacheThumbnail original File exists : true
D/FileTools: cacheThumbnail original file size : 92160
D/Utilities: orientBitmap FilePath : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/PNG_20161017_134748.png
D/Utilities: orientBitmap File exists : true
W/ExifInterface: Invalid image.
java.io.IOException: Invalid marker: 89
at android.media.ExifInterface.getJpegAttributes(ExifInterface.java:1600)
at android.media.ExifInterface.loadAttributes(ExifInterface.java:1339)
at android.media.ExifInterface.<init>(ExifInterface.java:1057)
at com.mypackage.helpers.Utilities.orientBitmap(Utilities.java:85)
at com.mypackage.fileio.FileTools.cacheThumbnail(FileTools.java:700)
at com.mypackage.coreapi.DownloadFileClass$downloadAndSaveFile(DownloadFileClass.java:215)
at com.mypackage.coreapi.DownloadFileClass$downloadAndSaveFile(DownloadFileClass.java:113)
at android.os.AsyncTask$2.call(AsyncTask.java:295)
at java.util.concurrent.FutureTask.run(FutureTask.java:237)
at android.os.AsyncTask$SerialExecutor$1.run(AsyncTask.java:234)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
at java.lang.Thread.run(Thread.java:818)
D/Utilities: After exception
D/Utilities: Thumb orientation : 0
D/FileTools: Save file to : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/PNG_20161017_134748.png
D/EncryptedFileTools: ......Final saved file path...... : /data/user/0/com.mypackage.myapp/cache/userhash/79640/media/encryptPlaceHolder
令人困惑的部分是,当我使用Android 4.4.4在我的Samsung Galaxy S4上运行应用程序时,我没有得到这个例外,但是当我在带有android 6.0.1的Samsung Galaxy S5上运行它时,我总是得到它.我也在使用Android 7.0的模拟器上出现此错误.我不知道如何解决这个问题.
请参阅附加的权限屏幕截图.
Enabled Permissions
我已添加了所需的信息.如果需要更多信息,请告诉我.我之前没有使用过ExifTags所以请耐心等待.
再次感谢.
解决方法:
我发现上面的代码存在问题.显然我试图直接从mp4和png文件中读取EXIF标签.在搜索有关EXIF标签的更多信息后,我发现EXIF标签仅适用于JPEG文件.因此我的问题的解决方法是首先创建mp4 / png文件的JPEG图像,然后尝试从此JPEF文件中读取EXIF标记.这样做解决了问题,我不再得到例外.
感谢大家指导我解决方案.
标签:android,image-rotation 来源: https://codeday.me/bug/20190702/1352442.html