MediaMetadataRetriever.setDataSource (native Methode) verursacht RuntimeException: status = 0x80000000
Ich versuche, mithilfe von android.media.MediaMetadataRetriever einige Metadateninformationen aus der JPG-Datei in meiner Android-App abzurufen. Hier ist mein Code:
public long getDuration(String videoFilePath, Context context) {
File file = loadVideoFile(videoFilePath);
if (file == null) {
return -1;
}
MediaMetadataRetriever retriever = new MediaMetadataRetriever();
file.setReadable(true, false);
retriever.setDataSource(file.getAbsolutePath());
return getDurationProperty(retriever);
}
Wenn ich die setDataSource-Methode aufrufe, wird eine RuntimeException ausgelöst:
09-10 15:22:25.576: D/PowerManagerService(486): releaseWakeLock(419aa2a0): CPU_MIN_NUM , tag=AbsListViewScroll_5.0, flags=0x400
09-10 15:22:26.481: I/HtcModeClient(12704): handler message = 4011
09-10 15:22:26.481: E/HtcModeClient(12704): Check connection and retry 9 times.
09-10 15:22:27.681: W/dalvikvm(13569): threadid=1: thread exiting with uncaught exception (group=0x40bc92d0)
09-10 15:22:27.696: E/AndroidRuntime(13569): FATAL EXCEPTION: main
09-10 15:22:27.696: E/AndroidRuntime(13569): java.lang.RuntimeException: setDataSource failed: status = 0x80000000
09-10 15:22:27.696: E/AndroidRuntime(13569): at android.media.MediaMetadataRetriever.setDataSource(Native Method)
09-10 15:22:27.696: E/AndroidRuntime(13569): at android.media.MediaMetadataRetriever.setDataSource(MediaMetadataRetriever.java:66)
Und seltsam ist, dass dies nur auf dem HTC One X mit Android 4.2.2 fehlschlägt. Anwendungen funktionieren problemlos mit anderen Geräten mit anderen Android-Versionen (z. B. 4.2.1).
Bearbeiten:
Beeindruckend. Vielleicht geht es um meine falsche Abhängigkeit in Maven:
<dependency>
<groupId>com.google.android</groupId>
<artifactId>android</artifactId>
<version>4.1.1.4</version>
<scope>provided</scope>
</dependency>
Aber ich kann keine Abhängigkeit für Android 4.2.2 finden. Wo finde ich es?