本文简单研究一下MediaScanner生成及保存thumbnail的方式,并给出代码快速查询图片的thumbnail,

希望可以抛块儿砖,引出一大堆玉来~

1. 手动执行Dev Tools /Media Scanner,或插入SD卡的时候,会启动MediaScannerService,把媒体文件更新到media数据库,

如果是图片文件会同时生成thumbnail

这部分代码在 packages\providers\MediaProvider

2. 数据库中图片及thumbnail的表结构

adb shell进入目录 /data/data/com.android.providers.media/databases

可以看到两个数据库internal.db external-xx.db,其中external.db中保存着sd卡中的媒体信息

我们用sqlit查看一下

sqlite3 external-xx.db

.table

可以看到有很多媒体文件相关的表,我们需要关心p_w_picpaths跟thumbnails这个表

p_w_picpaths表结构:

view plaincopy to clipboardprint?

p_w_picpaths (_id INTEGER PRIMARY KEY,_data TEXT,_s

ize INTEGER,_display_name TEXT,mime_type TEXT,title TEXT,date_added INTEGER,date

_modified INTEGER,description TEXT,picasa_id TEXT,isprivate INTEGER,latitude DOU

BLE,longitude DOUBLE,datetaken INTEGER,orientation INTEGER,mini_thumb_magic INTE

GER,bucket_id TEXT,bucket_display_name TEXT)

thumbnails表结构:

view plaincopy to clipboardprint?

thumbnails (_id INTEGER PRIMARY KEY,_

data TEXT,p_w_picpath_id INTEGER,kind INTEGER,width INTEGER,height INTEGER)

我们看一下在我的模拟器上实际的数据:

select * from p_w_picpaths;

view plaincopy to clipboardprint?

4|/mnt/sdcard/Android/1289887991860.jpg|40449|1289887991860.jpg|p_w_picpath/jpeg|12898

87991860|1290054484|1290064872||||||1290064872000|0|-5876966875320966333|1801299

020|Android

8|/mnt/sdcard/20101126062805_hahaha.bmp|65590|20101126062805_hahaha.bmp|p_w_picpath/x-

ms-bmp|20101126062805_hahaha|1290752887|1290752885||||||1290752885000||536666747

8445081544|-1595679508|sdcard

9|/mnt/sdcard/20101126064005_20101126062805_hahaha.bmp|65590|20101126064005_2010

1126062805_hahaha.bmp|p_w_picpath/x-ms-bmp|20101126064005_20101126062805_hahaha|129075

3607|1290753606||||||1290753606000||2418262411059016544|-1595679508|sdcard

select * from thumbnails;

view plaincopy to clipboardprint?

4|/mnt/sdcard/DCIM/.thumbnails/1290054484766.jpg|4|1|400|300

6|/mnt/sdcard/DCIM/.thumbnails/1290752887313.jpg|8|1|128|128

7|/mnt/sdcard/DCIM/.thumbnails/1290753608349.jpg|9|1|128|128

3. 现在可以看到sd卡下面的 DCIM/.thumbnails目录做什么用了,MediaScanner把生成的thumbnail放到这里,

并在数据库中来维护thumbnail跟图片的对应关系:

p_w_picpaths表中第一列是图片的id, 对应的thumbnail表中的p_w_picpath_id项

p_w_picpaths表中第二列式图片的路径,thumbnail表中第二列是thumbnail的路径

4. 从这个结果我们可以这样来查询某张图片的thumbnail (我自己想的,或许有更好的方法)

当前文件路径 ---> 查询p_w_picpaths表得到 _id ---> 用 _id = p_w_picpath_id查询thumbnials表 得到thumbnial 的路径

5. 根据文件路径file_path的到_id:

view plaincopy to clipboardprint?

String[] projection2 = {

"_id",

//"_data"

};

Uri uri2 = MediaStore.Images.Media.getContentUri("external");

String where = String.format(

"_data = '%s' ",

file_path);

Cursor c2 = Media.query(getContentResolver(), uri2,

projection2, where , null);

long p_w_picpath_id = c2.getLong(c2.getColumnIndexOrThrow("_id"));

6. 根据p_w_picpath_id查询thumbnail路径

view plaincopy to clipboardprint?

String[] projection = {

"_data" ,

//"p_w_picpath_id"

};

Cursor c = Thumbnails.queryMiniThumbnail(getContentResolver(), p_w_picpath_id,

Thumbnails.MINI_KIND, projection);

thumbnail_path = c.getString(c.getColumnIndexOrThrow("_data"));

7. 这样就从当前文件得到了对应的thumbnail,前提是MediaScanner帮你扫描过了,当然你也可以在代码中自己启动扫描

然后把thumnail路径传递给你用来显示的ImageView就可以了

Android8.thumbnails,Android Thumbnail 攻略相关推荐

  1. Android学习攻略:手把手教你循序渐进地学习Android知识

    前言 如果你也学习Android,那么你大概率会看过我的文章.经常有读者给我留言:"该怎么学习Android?"."日常学习Android的方法是什么". 所以 ...

  2. android游戏手柄,没手柄也不怕 键盘玩Android游戏攻略

    越来越多的朋友开始在手机等移动设备上享受游戏的乐趣,可不得不说用手指在触屏上玩游戏总有那么点不爽,于是乎,有玩家开始琢磨手机游戏新的玩法,为手机配上手柄(如下图),这其中既有专用的,也有将其他游戏平台 ...

  3. android游戏攻略,安卓手机游戏攻略

    攻略 独奏骑士70层如何通关 在独奏骑士中有很多的特色玩法,其中一个就是爬塔玩法,在这里有多个关卡,70层就是其中一关,也是比较复杂的一关,下面就跟着小编一起来看看70层通关方法吧!独奏骑士70层通 ...

  4. Android面试攻略

    文章背景 在外界看来IT是一个"高薪"的行业,都羡慕不已,熟不知IT也是一个苦逼的行业,每天加班加点,时刻用生命在写代码啊,导致许多程序猿和程序媛们都找不到对象,好不容易有个家庭的 ...

  5. WM平台玩转Android全攻略

    Android系统目前大行其道,flowermix也把玩过一段时间的G2,被Android系统的开放性和丰富的软件所吸引(我是重度测试控╮( ̄▽ ̄")╭ ). 相信大家早就看到过很多关于Wi ...

  6. flutter开发工具,2020年最全Android面试攻略

    摘要 开篇之前,首先说一下,大神就别点进来了.小编只是尘世间一个迷途小开发,二流程序员. 这篇文章并不像其他面经一样金光闪闪,只是一个二流Android攻城狮在市场的大潮之下,用一个月时间面试+复习+ ...

  7. Android出海攻略(一):Google Play 上架扫盲

    由于某些 不(xin)可(zhi)描(du)述(ming) 的原因,缺少"武林盟主"的国内Android市场一直比较混乱,应用分发.应用质量管控.权限管控.隐私管控 等各方面都不被 ...

  8. Android网络优化攻略,简单了解一下?

    转自:掘金 - 究极逮虾户 https://juejin.cn/post/6896302142542315533 1  如何优化一个网络请求呢? 相信大家在面试的时候可能会被问到这个问题.今天我其实就 ...

  9. Android学习攻略:该如何循序渐进地学习Android知识?,android棋牌游戏开发

    ####1.1 初级 ####1.2 中级 ####1.3 高级 ####1.4 高级以上 针对高级以上的Android开发者,我认为主要是有3个方向:​技术专家.架构师 & 管理层​,具体介 ...

最新文章

  1. 再谈符号间干扰(一)
  2. 论网站更新与seo优化的关系
  3. C#中的thread和task之 Thread ThreadPool
  4. C++11 override 和 final 关键字
  5. 下列选项中非法的c语言转义字符,c语言练习题t答案
  6. 无刷直流电机学习笔记5
  7. 爬虫项目报错Traceback (most recent call last): File D:/studay/python/one/day01/07_post请求.py, line 38,
  8. JsDroid2开发教程
  9. 最高人民法院 最高人民检察院 关于办理非法利用信息网络、帮助信息网络犯罪活动等刑事案件适用法律若干问题的解释(重点学习标注)...
  10. YDOOK: ANSYS Maxwell 19 教程21:Maxwell 2D 直流传导电场 求解设置 分析设置
  11. 改进YOLOv7系列:24.添加SimAM注意力机制
  12. java实现简单学生信息管理系统
  13. h5 页面唤起微信和qq
  14. verilog驱动1602液晶屏
  15. Bulletproof零知识证明
  16. 申请GitHub学生包,0成本搭建WordPress教程
  17. java添加tomcat_Java以及Tomcat配置
  18. 小程序最新获取头像和昵称
  19. 利用Matlab进行相机标定并使用openCV进行简单三维重建
  20. 华为机试真题 C++ 实现【跳格子】

热门文章

  1. Swift 周报 第九期
  2. PixiJS学习(10)事件机制
  3. 网优谷给大家简介SEO
  4. 秋色园QBlog技术原理解析:UrlRewrite之URL重定向体系(四)
  5. 优雅的实现 Excel 导入导出
  6. 转:POI操作Excel:cell的背景颜色类型
  7. 上海房价和东京房价比较
  8. 华硕主板固态硬盘不识别_如果ASUS主板BIOS主板无法识别NVMe m.2 SSD,该怎么办?...
  9. windows cmd设置ip\dns地址
  10. 浅析英语五大成分-主谓宾定状