2010-12-14 5 views
5

Возможно ли получить миниатюрное изображение с видеоролика? Мне нужно создавать миниатюры видео в виде списка.thumbnail image of video url

+0

увидеть мой ответ ... – Lokesh

+0

@ user3726986 является его ContentProvider Url или Url, как YouTube? – SMR

ответ

0

Очень важно идентифицировать компоненты проблемы. Я бы сказал, что у вас есть две отдельные проблемы:

  1. Загрузка файла по URL-адресу.

  2. Создание миниатюры из неполного видеофайла.

Посмотрите эти два отдельно, вы найдете много информации.

9

Да, возможно, получить миниатюру видео с помощью ThumbnailUtils.

FileOutputStream out; 
File land=new File(Environment.getExternalStorageDirectory().getAbsoluteFile() 
       +"/portland.jpg");// image file use to create image u can give any path. 
Bitmap bitmap=ThumbnailUtils.createVideoThumbnail(filePath, MediaStore.Video.Thumbnails.FULL_SCREEN_KIND);//filePath is your video file path. 
     ByteArrayOutputStream stream = new ByteArrayOutputStream(); 
     bitmap.compress(Bitmap.CompressFormat.JPEG, 100, stream); 
     byte[] byteArray = stream.toByteArray(); 

     out=new FileOutputStream(land.getPath()); 
     out.write(byteArray); 
     out.close(); 
+0

Я не могу использовать эту строку, Показывает ошибку, File land = new File (Environment.getExternalStorageDirectory(). GetAbsoluteFile() + "/ portland.jpg "); – Anitha

+0

Я получаю изображение из видеоролика, а затем то, что я делаю? .. Пожалуйста, помогите мне. –

+0

Лучшее уникальное решение, так как в отличие от MINI_KIND и MICRO_KIND, FULL_SCREEN_KIND хранится только на db и недоступен для доступа по пути URI. – MPaulo

1

Попробуйте ThumbnailUtils, чтобы получить видео растрового изображения из пути

ThumbnailUtils.createVideoThumbnail(filePath,MediaStore.Video.Thumbnails.MINI_KIND); 
+0

нет, когда вы переходите. –

2

файла Если вы специально спрашивать о youtube видео, то есть автоматически генерируется 4 изображения на Youtube.

http://img.youtube.com/vi/video_url_here/0.jpg 
http://img.youtube.com/vi/video_url_here/1.jpg 
http://img.youtube.com/vi/video_url_here/2.jpg 
http://img.youtube.com/vi/video_url_here/3.jpg 

Стандартные размеры изображений

игрока фона миниатюру (480x360 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/0.jpg

Start миниатюр (120x90 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/1.jpg

Средний уменьшенных изображений (120x90 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/2.jpg

End Thumbnail (120x90 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/3.jpg

Высокое качество Миниатюра (480x360 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/hqdefault.jpg

среднего качества Миниатюра (320x180 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/mqdefault.jpg

Нормальное качество Миниатюра (120x90 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/default.jpg

Миниатюра стандартного разрешения (640x480 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/sddefault.jpg

Максимальное разрешение Thumbnail (1920х1080 пикселей) http://i1.ytimg.com/vi/G0wGs3useV8/maxresdefault.jpg

0

можно получить миниатюру из видео файла или URL с помощью FFMPEG.

FFMPEG должен быть построен с использованием NDK (или вы можете найти некоторые встроенные в Android FFMPEG-файлы).Вот проект GitHub построить FFMPEG:

https://github.com/guardianproject/android-ffmpeg

Вы можете включать FFmpeg двоичные файлы с приложением и выполнять FFMPEG из кода в приложении для создания изображения из видео (локальный или URL) с использованием команда, как:

ffmpeg -i videosite.com/video.flv -ss 00:00:15.000 -vframes 1 thumbnail_out.png 

Одна вещь, чтобы рассмотреть это на то, что время поиска (опция -ss) вы захватить миниатюру для того, чтобы быть содержательным изображение, которое представляет собой видео.

0

Чтобы получить миниатюру из URL, я получил только одно решение до сих пор, Вы должны использовать This library

Он поддерживает файл, HTTP, HTTPS, MMS, MMSh и RTMP протоколы

и

Он поддерживает aac, acc +, avi, flac, mp2, mp3, mp4, ogg, 3gp и многое другое! форматы (аудио и видео):

1

Возможно получить миниатюру изображения с видеоролика.

Если ваш тип видео Vimeo следуйте ниже шагов:

1) Предположим, что ваш URL видео является: http://player.vimeo.com/video/17314292

2) Получить идентификатор видео из URL: например.

3) Вызова WS с видео Ид и форматом XML http://vimeo.com/api/v2/video/17314292.xml

вы получите "thumbnail_small", "thumbnail_medium", "thumbnail_large" в формате XML для видео эмпирического из видео ид

Если ваш тип видео YouTube следовать ниже шаги:

1) URL видео: http://www.youtube.com/embed/Nl2iMF0yKW8

2) Получить идентификатор видео по адресу: например. Nl2iMF0yKW8

3) Заменить идентификатор видео в этом URL http://i3.ytimg.com/vi/Nl2iMF0yKW8/default.jpg

ПРИМЕЧАНИЕ: Просто замените ваш идентификатор здесь.

1

Он работает в моем случае

Uri videoUri = data.getData(); 
       String selectedPathVideo=""; 
       selectedPathVideo = ImageFilePath.getPath(getApplicationContext(), videoUri); 
       Log.i("Image File Path", ""+selectedPathVideo); 

       try { 
        Bitmap thumb = ThumbnailUtils.createVideoThumbnail(selectedPathVideo, MediaStore.Video.Thumbnails.MICRO_KIND); 


        imgFarmerVideo.setImageBitmap(thumb); 

       } catch (Exception e) { 
        e.printStackTrace(); 
       } 

Поддержка файлов

public class ImageFilePath { 
    /** 
    * Method for return file path of Gallery image 
    * 
    * @param context 
    * @param uri 
    * @return path of the selected image file from gallery 
    */ 
    public static String getPath(final Context context, final Uri uri) 
    { 

     //check here to KITKAT or new version 
     final boolean isKitKat = Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT; 

     // DocumentProvider 
     if (isKitKat && DocumentsContract.isDocumentUri(context, uri)) { 

      // ExternalStorageProvider 
      if (isExternalStorageDocument(uri)) { 
       final String docId = DocumentsContract.getDocumentId(uri); 
       final String[] split = docId.split(":"); 
       final String type = split[0]; 

       if ("primary".equalsIgnoreCase(type)) { 
        return Environment.getExternalStorageDirectory() + "/" + split[1]; 
       } 
      } 
      // DownloadsProvider 
      else if (isDownloadsDocument(uri)) { 

       final String id = DocumentsContract.getDocumentId(uri); 
       final Uri contentUri = ContentUris.withAppendedId(
         Uri.parse("content://downloads/public_downloads"), Long.valueOf(id)); 

       return getDataColumn(context, contentUri, null, null); 
      } 
      // MediaProvider 
      else if (isMediaDocument(uri)) { 
       final String docId = DocumentsContract.getDocumentId(uri); 
       final String[] split = docId.split(":"); 
       final String type = split[0]; 

       Uri contentUri = null; 
       if ("image".equals(type)) { 
        contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI; 
       } else if ("video".equals(type)) { 
        contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI; 
       } else if ("audio".equals(type)) { 
        contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI; 
       } 

       final String selection = "_id=?"; 
       final String[] selectionArgs = new String[] { 
         split[1] 
       }; 

       return getDataColumn(context, contentUri, selection, selectionArgs); 
      } 
     } 
     // MediaStore (and general) 
     else if ("content".equalsIgnoreCase(uri.getScheme())) { 

      // Return the remote address 
      if (isGooglePhotosUri(uri)) 
       return uri.getLastPathSegment(); 

      return getDataColumn(context, uri, null, null); 
     } 
     // File 
     else if ("file".equalsIgnoreCase(uri.getScheme())) { 
      return uri.getPath(); 
     } 

     return null; 
    } 

    /** 
    * Get the value of the data column for this Uri. This is useful for 
    * MediaStore Uris, and other file-based ContentProviders. 
    * 
    * @param context The context. 
    * @param uri The Uri to query. 
    * @param selection (Optional) Filter used in the query. 
    * @param selectionArgs (Optional) Selection arguments used in the query. 
    * @return The value of the _data column, which is typically a file path. 
    */ 
    public static String getDataColumn(Context context, Uri uri, String selection, 
             String[] selectionArgs) { 

     Cursor cursor = null; 
     final String column = "_data"; 
     final String[] projection = { 
       column 
     }; 

     try { 
      cursor = context.getContentResolver().query(uri, projection, selection, selectionArgs, 
        null); 
      if (cursor != null && cursor.moveToFirst()) { 
       final int index = cursor.getColumnIndexOrThrow(column); 
       return cursor.getString(index); 
      } 
     } finally { 
      if (cursor != null) 
       cursor.close(); 
     } 
     return null; 
    } 

    /** 
    * @param uri The Uri to check. 
    * @return Whether the Uri authority is ExternalStorageProvider. 
    */ 
    public static boolean isExternalStorageDocument(Uri uri) { 
     return "com.android.externalstorage.documents".equals(uri.getAuthority()); 
    } 

    /** 
    * @param uri The Uri to check. 
    * @return Whether the Uri authority is DownloadsProvider. 
    */ 
    public static boolean isDownloadsDocument(Uri uri) { 
     return "com.android.providers.downloads.documents".equals(uri.getAuthority()); 
    } 

    /** 
    * @param uri The Uri to check. 
    * @return Whether the Uri authority is MediaProvider. 
    */ 
    public static boolean isMediaDocument(Uri uri) { 
     return "com.android.providers.media.documents".equals(uri.getAuthority()); 
    } 

    /** 
    * @param uri The Uri to check. 
    * @return Whether the Uri authority is Google Photos. 
    */ 
    public static boolean isGooglePhotosUri(Uri uri) { 
     return "com.google.android.apps.photos.content".equals(uri.getAuthority()); 
    } 
}