`

2011.09.27——— android 视频缩略图之MediaMetadataRetriever

阅读更多
2011.09.27——— android 视频缩略图之MediaMetadataRetriever

参考:http://www.ophonesdn.com/forum/thread-2973-1-1.html
http://topic.csdn.net/u/20100315/10/2726b427-ca14-4e06-bd44-a6a351f8c52a.html
http://www.pin5i.com/showtopic-android-generate-thumbnails-for-multimedia-files.html
1、
2.2之后 获得缩略图就简单了 因为用了ThumbnailUtils类,可以

Bitmap  b = ThumbnailUtils.createVideoThumbnail(path,Video.Thumbnails.MICRO_KIND);
ImageView iv = new ImageView(this);

参见:http://lipeng88213.iteye.com/blog/835183

2、
但是2.2之前呢 这个问题就比较郁闷了 查了查资料
其实 我们可以用MediaMetadataRetriever这个类

但是 里面有个问题
1.0之后 这个类被隐藏了 貌似2.3之后这个类又出现了吧

隐藏了。。。。那怎么办呢?别慌 我们自有办法  步骤如下:

一、找到MediaMetadataRetriever的源码 复制到你的工程里面去

切忌:包名必须与MediaMetadataRetriever本身在系统里面的包名一样,也就是包名必须为android.media





二、找到so文件 新建一个和src同级别的libs文件夹 把so文件复制进去 这个so文件的名字大概为libmedia_jni.so




可能有人要问 如何获得so文件呢 方法有两个
A:如果你有android的系统源码 你直接可以搜索libmedia_jni.so 就能得到
B:在androidsdk目录——tools——ddms.bat 启动ddms



Device——File Explore
打开一个文件浏览器



system——lib——libmedia_jni.so




三、
这样之后 你就可以用MediaMetadataRetriever类了

MediaMetadataRetriever主要有两个功能:MODE_GET_METADATA_ONLY和MODE_CAPTURE_FRAME_ONLY

mode为MODE_CAPTURE_FRAME_ONLY时
调用captureFrame取得一帧。
mode为MODE_GET_METADATA_ONLY时
extractMetadata 提取文件信息,ARTIST、DATE、YEAR、DURATION、RATING、FRAME_RATE、VIDEO_FORMAT 可以得到时长等信息
和extractAlbumArt 提取专辑信息,这个下面的音乐文件可以用到。


代码如下:
获得缩略图
private Bitmap createVideoThumbnail(String filePath) {
        Bitmap bitmap = null;
        android.media.MediaMetadataRetriever retriever = new android.media.MediaMetadataRetriever();
        
        try {
            retriever.setMode(android.media.MediaMetadataRetriever.MODE_CAPTURE_FRAME_ONLY);
            retriever.setDataSource(filePath);
            bitmap = retriever.captureFrame();
        } catch(IllegalArgumentException ex) {
            // Assume this is a corrupt video file
        } catch (RuntimeException ex) {
            // Assume this is a corrupt video file.
        } finally {
            try {
                retriever.release();
            } catch (RuntimeException ex) {
                // Ignore failures while cleaning up.
            }
        }
        return bitmap;
    }


获得时长   
   
private String ttt(String filePath){
    	android.media.MediaMetadataRetriever retriever = new android.media.MediaMetadataRetriever();
    	retriever.setMode(android.media.MediaMetadataRetriever.MODE_GET_METADATA_ONLY);
    	retriever.setDataSource(filePath);
    	String str = retriever.extractMetadata(android.media.MediaMetadataRetriever.METADATA_KEY_DURATION);
        System.out.println(str +"  =====");
        return str;
    }



代码见附件


另外:

我同事有一个获得缩略图另辟蹊径的方法 大致思路如下
偷偷的将视频播放0.1秒 然后通过VideoView.getDrawingCache()方法 来获得缓存的图片 这个就可以为视频的缩略图
此方法可行!





  • 大小: 10.9 KB
  • 大小: 6.9 KB
  • 大小: 36.5 KB
  • 大小: 27.8 KB
  • 大小: 106.1 KB
分享到:
评论
7 楼 lipeng88213 2013-07-31  
whsky 写道
上面的错误没解决?

这个是很早之前用过的,之后我也没用了 要不你找下其他方法吧
6 楼 whsky 2013-07-29  
上面的错误没解决?
5 楼 xiaopanp 2013-02-02  
02-02 17:31:50.120: E/AndroidRuntime(24849): java.lang.NoSuchMethodError: android.media.MediaMetadataRetriever.setMode
02-02 17:31:50.120: E/AndroidRuntime(24849): at com.lp.MainActivity.createVideoThumbnail(MainActivity.java:35)
02-02 17:31:50.120: E/AndroidRuntime(24849): at com.lp.MainActivity.onCreate(MainActivity.java:21)
02-02 17:31:50.120: E/AndroidRuntime(24849): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
02-02 17:31:50.120: E/AndroidRuntime(24849): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1618)
02-02 17:31:50.120: E/AndroidRuntime(24849): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1670)
02-02 17:31:50.120: E/AndroidRuntime(24849): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
02-02 17:31:50.120: E/AndroidRuntime(24849): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
02-02 17:31:50.120: E/AndroidRuntime(24849): at android.os.Handler.dispatchMessage(Handler.java:99)
02-02 17:31:50.120: E/AndroidRuntime(24849): at android.os.Looper.loop(Looper.java:123)
02-02 17:31:50.120: E/AndroidRuntime(24849): at android.app.ActivityThread.main(ActivityThread.java:3695)
02-02 17:31:50.120: E/AndroidRuntime(24849): at java.lang.reflect.Method.invokeNative(Native Method)
02-02 17:31:50.120: E/AndroidRuntime(24849): at java.lang.reflect.Method.invoke(Method.java:507)
02-02 17:31:50.120: E/AndroidRuntime(24849): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
02-02 17:31:50.120: E/AndroidRuntime(24849): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
02-02 17:31:50.120: E/AndroidRuntime(24849): at dalvik.system.NativeStart.main(Native Method)
4 楼 a379933101 2012-08-13  
好人啊,非常感谢
3 楼 iverson03 2012-07-23  
我也出现上述错误。求解......
2 楼 huangzubin13 2012-07-11  
远行报错
I/System.out(13902): /mnt/sdcard
D/AndroidRuntime(13902): Shutting down VM
W/dalvikvm(13902): threadid=1: thread exiting with uncaught exception (group=0x40015560)
E/AndroidRuntime(13902): FATAL EXCEPTION: main
E/AndroidRuntime(13902): java.lang.NoSuchMethodError: android.media.MediaMetadataRetriever.setMode
E/AndroidRuntime(13902): at com.lp.MainActivity.createVideoThumbnail(MainActivity.java:35)
E/AndroidRuntime(13902): at com.lp.MainActivity.onCreate(MainActivity.java:21)
E/AndroidRuntime(13902): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
E/AndroidRuntime(13902): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
E/AndroidRuntime(13902): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
E/AndroidRuntime(13902): at android.app.ActivityThread.access$1500(ActivityThread.java:117)
E/AndroidRuntime(13902): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
E/AndroidRuntime(13902): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(13902): at android.os.Looper.loop(Looper.java:130)
E/AndroidRuntime(13902): at android.app.ActivityThread.main(ActivityThread.java:3683)
E/AndroidRuntime(13902): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(13902): at java.lang.reflect.Method.invoke(Method.java:507)
E/AndroidRuntime(13902): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
E/AndroidRuntime(13902): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
E/AndroidRuntime(13902): at dalvik.system.NativeStart.main(Native Method)
W/ActivityManager(  104):   Force finishing activity com.lp/.MainActivity
W/ActivityManager(  104):   Force finishing activity com.android.settings/.DevelopmentSettings
W/ActivityManager(  104): Scheduling restart of crashed service com.duomi.android/com.duomi.app.player.DMMusicService in 33436ms
W/ActivityManager(  104): Activity pause timeout for HistoryRecord{406403e0 com.lp/.MainActivity}
D/AudioHardware(12450): AudioHardware pcm playback is exiting standby.
D/AudioHardware(12450): openPcmOut_l() mPcmOpenCnt: 0
I/Process (13902): Sending signal. PID: 13902 SIG: 9
1 楼 huangzubin13 2012-07-11  
膜拜lz 

相关推荐

Global site tag (gtag.js) - Google Analytics