主要分为几节:css 1. Android的媒体文件内部是如何存储的?android 2. Andoid的媒体文件如何获取?git 3. 在使用媒体文件的一些小技巧。数据库 1. Android的多媒体如何存储的?app Android的多媒体文件主要存储在/data/data/com.android.providers.media/databases目录下,该目录下有两个db文件,一个是内部存储数据库文件(internal.db),一个是存储卡数据库(external-XXXX.db)。媒体文件的操做主要是围绕着这两个数据库来进行。这两个数据库的结构是彻底如出一辙的。ide 咱们先看一下这两个数据库包含了哪些表。url album_art audio searchspa album_info audio_genres searchhelpertitlecode albums audio_genres_map thumbnails视频 android_metadata audio_meta video artist_info audio_playlists videothumbnails artists audio_playlists_map artists_albums_map images 先从基本的分析: Images表:主要存储images信息。能够看一下这个表的结构: CREATE TABLE images (_id INTEGER PRIMARY KEY,_data TEXT,_size INTEGER,_display_name TEXT,mime_type TEXT,title TEXT,date_added INTEGER,date_modified INTEGER,description TEXT,picasa_id TEXT,isprivate INTEGER,latitude DOUBL E,longitude DOUBLE,datetaken INTEGER,orientation INTEGER,mini_thumb_magic INTEGER,bucket_id TEXT,bucket_displa y_name TEXT); 包含了一些基本信息,其中你们一看就明白了。 Thumbnails表:这个表和images表是有直接关系的。主要存储图片的缩略图,Android为每一张保存进系统的图片文件都会自动生成一张缩略图文件。关于这一点还有一些特殊的技巧后面再讲。咱们能够看一下这个表的结构: CREATE TABLE thumbnails (_id INTEGER PRIMARY KEY,_data TEXT,image_id INTEGER,kind INTEGER,width INTEGER,height INTEGER); 每一张image对应一条thumbnail记录。 Video表:主要存储视频信息了。和images表相似。表结构以下: CREATE TABLE video (_id INTEGER PRIMARY KEY,_data TEXT NOT NULL,_display_name TEXT,_size INTEGER,mime_type TEXT,date_added INTEGER,date_modified INTEGER,title TEXT,duration INTEGER,artist TEXT,album TEXT,resolution TEXT,description TEXT,isprivate INTEGER,tags TEXT,category TEXT,language TEXT,mini_thumb_data TEXT,latitude DOUBLE,longitude DOUBLE,datetaken INTEGER,mini_thumb_magic INTEGER, bucket_id TEXT, bucket_display_name TEXT, bookmark INTEGER); Videothumbnails表:存储视频的缩略图信息。这个和thumbnails表相似。 Audio表:音频信息比视频信息和图片信息要稍微复杂一些,主要是存储了一些专辑(album)、歌手(artists)信息,而专辑和歌手信息是单独的表格存储的,audio实际上是一个视图,真正的音频数据信息存储在audio_meta表格中。咱们能够看一下audio视图的定义: CREATE VIEW audio as SELECT * FROM audio_meta LEFT OUTER JOIN artists ON audio_meta.artist_id=artists.artist_id LEFT OUTER JOIN albums ON audio_meta.album_id=albums.album_id; Albums表:主要存储专辑信息。 Artists表:主要存储歌手信息。很少赘述。 其余的一些表格咱们平时可能用的比较少,就不作描述了,有兴趣能够自行研究一下。
- 2. Android的多媒体如何获取?
Android提供了媒体获取与存储的相关API,主要包含在android.provider.MediaStorepackage中。
MediaStore.Audio.AlbumColumns |
Columns representing an album |
MediaStore.Audio.ArtistColumns |
Columns representing an artist |
MediaStore.Audio.AudioColumns |
Columns for audio file that show up in multiple tables. |
MediaStore.Audio.GenresColumns |
Columns representing an audio genre |
MediaStore.Audio.PlaylistsColumns |
Columns representing a playlist |
MediaStore.Files.FileColumns |
Fields for master table for all media files. |
MediaStore.Images.ImageColumns |
|
MediaStore.MediaColumns |
Common fields for most MediaProvider tables |
MediaStore.Video.VideoColumns |
|
MediaStore |
The Media provider contains meta data for all available media on both internal and external storage devices. |
MediaStore.Audio |
Container for all audio content. |
MediaStore.Audio.Albums |
Contains artists for audio files |
MediaStore.Audio.Artists |
Contains artists for audio files |
MediaStore.Audio.Artists.Albums |
Sub-directory of each artist containing all albums on which a song by the artist appears. |
MediaStore.Audio.Genres |
Contains all genres for audio files |
MediaStore.Audio.Genres.Members |
Sub-directory of each genre containing all members. |
MediaStore.Audio.Media |
|
MediaStore.Audio.Playlists |
Contains playlists for audio files |
MediaStore.Audio.Playlists.Members |
Sub-directory of each playlist containing all members. |
MediaStore.Files |
Media provider table containing an index of all files in the media storage, including non-media files. |
MediaStore.Images |
Contains meta data for all available images. |
MediaStore.Images.Media |
|
MediaStore.Images.Thumbnails |
This class allows developers to query and get two kinds of thumbnails: MINI_KIND: 512 x 384 thumbnail MICRO_KIND: 96 x 96 thumbnail |
MediaStore.Video |
|
MediaStore.Video.Media |
|
MediaStore.Video.Thumbnails |
This class allows developers to query and get two kinds of thumbnails: MINI_KIND: 512 x 384 thumbnail MICRO_KIND: 96 x 96 thumbnail |
简单的观察一下,发现这些类也就是对数据库中的一些表的封装,弄懂了底层的存储结构,对于了解这些类的做用就很容易了。 Android系统中的每一种媒体文件有两种地址描述方式。 第一种模式,你们知道,在Android中,Content Provider是用来存储和获取公共数据的统一接口,Content Provider为每一类资源分配了URI地址,好比图片的地址就包括MediaStore.Images.Media.INTERNAL_CONTENT_URI和MediaStore.Images.Media.EXTERNAL_CONTENT_URI两个基础地址,其值分别是content://media/internal/images/media和content://media/external/images/media,对应内部库和外部库地址。每一张图片的地址基本上是上面的基础URL地址下加上图片的内部ID。打个比方一张存储卡上的图片ID为2,其对应的Uri地址就是content://media/external/images/media/2.知道了这个地址,基本上就能够操做这张图片的全部信息了。 另一种描述文件地址标识就是传统的文件路径模式了,好比一张存储卡上的图片地址可能描述为:/mnt/sdcard/images/1.jpg。其实这个路径存储在images表格中的data字段中,有了这点关联,咱们能够在这两种模式下进行任意切换。 前一种模式下,主要经过MediaStore.Images.Media、MediaStore.Audio.Media、MediaStore.Video.Media三个库中的query方法来查询或者获取特定条件的媒体了。 基本用法1:从一个Content Uri地址中生成Bitmap 能够采用android.provider.MediaStore.Images.Media.getBitmap(ContentResolver cr, Uri url)方法,其中ContentResolver是应用与资源之间的衔接人,它的示例一般能够经过在Activity中调用的getContentResolver()方法中获取。Uri地址就是上面描述的content://media/external/images/media/2相似地址,也就是Content Provider定义的地址形式。 基本用法2:从一个传统地址中生成Bitmap 有时候咱们只知道一张图片的路径,并不知道图片的内部地址,想去获取该图片,能够采用android.graphics.BitmapFactory中的decodeXXX方法来搞定,好比decodeFile方法就是从文件路径中读取图片,原图片能够支持jpg,png,gif,bmp等各类格式。decodeByteArray就是从字节流中解码了。最后都是转换成Bitmap格式。 基本用法3:获取一张图片的缩略图 有时候咱们须要显示图片的缩略图,能够采用android.provider.MediaStore.Images.Thumbnails的getThumbnail方法。另外其实也能够采用bitmap的compress的方法对图片进行一些压缩处理。 |