布局及特效  gallery3d 的精华
一、布局
gallery3d的界面生成和普通的应用程序不一样。普通程序一般一个界面就是一个activity,布局用xml或代码都可以实现,界面切换是activity的切换方式;而gallery3d没有用android的UI系统,而是用opengl画出来的,即界面是在同一个 activity的,如主界面,缩略图界面,单张图片查看界面,标记界面等都属于同一个activity。那么这界面布局不同的界面是如何组合到一起的呢?分析代码,可以把它看成一个状态机:  
1、标记模式   public static final int MODE_SELECT = 1;(HudLayer)
包含了主界面标记模式,缩略界面矩阵游览时标记模式、缩略图界面分类游览时标记模式3个界面
2、普通模式  public static final int MODE_NORMAL = 0;(HudLayer)
包含了

Java代码
  1. public static final int STATE_MEDIA_SETS = 0;主界面
  2. public static final int STATE_GRID_VIEW = 1;缩略图矩阵浏览
  3. public static final int STATE_FULL_SCREEN = 2;查看界面
  4. public static final int STATE_TIMELINE = 3;缩略图界面分类浏览
public static final int STATE_MEDIA_SETS = 0;主界面public static final int STATE_GRID_VIEW = 1;缩略图矩阵浏览public static final int STATE_FULL_SCREEN = 2;查看界面public static final int STATE_TIMELINE = 3;缩略图界面分类浏览

有了以上状态分类后,在渲染的时候就能根据些界面的组成来定哪些控件譔隐藏,哪些要显示了。
下面是基本控件:

Java代码
  1. com.cooliris.media.GridLayer
  2. com.cooliris.media.BackgroundLayer
  3. com.cooliris.media.HudLayer
  4. com.cooliris.media.ImageButton
  5. com.cooliris.media.TimeBar
  6. com.cooliris.media.MenuBar
  7. com.cooliris.media.PopupMenu
  8. com.cooliris.media.PathBarLayer
com.cooliris.media.GridLayer
com.cooliris.media.BackgroundLayer
com.cooliris.media.HudLayer
com.cooliris.media.ImageButton
com.cooliris.media.TimeBar
com.cooliris.media.MenuBar
com.cooliris.media.PopupMenu
com.cooliris.media.PathBarLayer

在渲染时,每一帧所有界面上的元素都画了,由于根据上面的状态只把特定窗口的特定元素显示出来,其它窗口中的隐藏,所以不会乱。
Layer是上面控件的基类,上面控件的类也就有了下面两个方法来隐藏不譔显示的界面元素。

Java代码
  1. public boolean isHidden() {
  2. return mHidden;
  3. }
  4. public void setHidden(boolean hidden) {
  5. if (mHidden != hidden) {
  6. mHidden = hidden;
  7. onHiddenChanged();
  8. }
  9. }
public boolean isHidden() {return mHidden;}public void setHidden(boolean hidden) {if (mHidden != hidden) {mHidden = hidden;onHiddenChanged();}}

下面是根据上面分类来画不同元素所用的标识:

Java代码
  1. public static final int PASS_THUMBNAIL_CONTENT = 0;
  2. public static final int PASS_FOCUS_CONTENT = 1;
  3. public static final int PASS_FRAME = 2;
  4. public static final int PASS_PLACEHOLDER = 3;
  5. public static final int PASS_FRAME_PLACEHOLDER = 4;
  6. public static final int PASS_TEXT_LABEL = 5;
  7. public static final int PASS_SELECTION_LABEL = 6;
  8. public static final int PASS_VIDEO_LABEL = 7;
  9. public static final int PASS_LOCATION_LABEL = 8;
  10. public static final int PASS_MEDIASET_SOURCE_LABEL = 9;
 public static final int PASS_THUMBNAIL_CONTENT = 0;public static final int PASS_FOCUS_CONTENT = 1;public static final int PASS_FRAME = 2;public static final int PASS_PLACEHOLDER = 3;public static final int PASS_FRAME_PLACEHOLDER = 4;public static final int PASS_TEXT_LABEL = 5;public static final int PASS_SELECTION_LABEL = 6;public static final int PASS_VIDEO_LABEL = 7;public static final int PASS_LOCATION_LABEL = 8;public static final int PASS_MEDIASET_SOURCE_LABEL = 9;
Java代码
  1. drawDisplayItem(view, gl, displayItem, texture, PASS_THUMBNAIL_CONTENT, placeholder,displayItem.mAnimatedPlaceholderFade); 画缩略图的,注掉此句,前两屏只显示框,第三屏OK
  2. drawDisplayItem(view, gl, displayItem, texture, PASS_FOCUS_CONTENT, null, 0.0f);画单张图片的,注掉,第三屏黑屏
  3. drawDisplayItem(view, gl, itemDrawn, textureToUse, PASS_FRAME, previousTexture, ratio);画边框的,注掉,前两屏明显没有边框,巨齿明显
  4. drawDisplayItem(view, gl, displayItem, textureString, PASS_TEXT_LABEL, null, 0);画文本标签的
  5. drawDisplayItem(view, gl, displayItem, textureToUse, PASS_SELECTION_LABEL, null, 0);画选中标记的
  6. drawDisplayItem(view, gl, displayItem, videoTexture, PASS_VIDEO_LABEL, null, 0);画视频标记的
  7. drawDisplayItem(view, gl, displayItem, locationTexture, PASS_LOCATION_LABEL, null, 0);画位置标记的
  8. drawDisplayItem(view, gl, displayItem, locationTexture, PASS_MEDIASET_SOURCE_LABEL,transparentTexture, 0.85f);画源来源图标的(相机或一般文件夹)
drawDisplayItem(view, gl, displayItem, texture, PASS_THUMBNAIL_CONTENT, placeholder,displayItem.mAnimatedPlaceholderFade); 画缩略图的,注掉此句,前两屏只显示框,第三屏OK
drawDisplayItem(view, gl, displayItem, texture, PASS_FOCUS_CONTENT, null, 0.0f);画单张图片的,注掉,第三屏黑屏
drawDisplayItem(view, gl, itemDrawn, textureToUse, PASS_FRAME, previousTexture, ratio);画边框的,注掉,前两屏明显没有边框,巨齿明显
drawDisplayItem(view, gl, displayItem, textureString, PASS_TEXT_LABEL, null, 0);画文本标签的
drawDisplayItem(view, gl, displayItem, textureToUse, PASS_SELECTION_LABEL, null, 0);画选中标记的
drawDisplayItem(view, gl, displayItem, videoTexture, PASS_VIDEO_LABEL, null, 0);画视频标记的
drawDisplayItem(view, gl, displayItem, locationTexture, PASS_LOCATION_LABEL, null, 0);画位置标记的
drawDisplayItem(view, gl, displayItem, locationTexture, PASS_MEDIASET_SOURCE_LABEL,transparentTexture, 0.85f);画源来源图标的(相机或一般文件夹)

二、特效
举如何显示一张图片为例,在图片完全显示出来经过这样一个过程,附近的图片渐小渐出,当前图片渐大渐入,当前图片逐渐变大直到全屏。实现这个特效,要进行很多帧的渲染。就是说并不是只调一次onDrawFrame函数就可以了,要调用多次。可以把这个特效的实现想成一个状态变化的过程,在每一个状态,纹理的显示大小和位置都不同,这也符合动画的基本原理。放大、缩小我们只要改变顶点数据就可以做到,gallery3d也是这样做的,下面是主要代码:
我们知道调用onDrawFrame来渲染,最后调到下面的drawFocusItems函数,

Java代码
  1. GridQuad quad = GridDrawables.sFullscreenGrid[vboIndex];
  2. float u = texture.getNormalizedWidth();
  3. float v = texture.getNormalizedHeight();
  4. float imageWidth = texture.getWidth();
  5. float imageHeight = texture.getHeight();
  6. boolean portrait = ((theta / 90) % 2 == 1);
  7. if (portrait) {
  8. viewAspect = 1.0f / viewAspect;
  9. }
  10. quad.resizeQuad(viewAspect, u, v, imageWidth, imageHeight);//改变用来贴图片的长方形的大小
  11. quad.bindArrays(gl);//绑定新数据,为渲染做准备。
GridQuad quad = GridDrawables.sFullscreenGrid[vboIndex];
float u = texture.getNormalizedWidth();
float v = texture.getNormalizedHeight();
float imageWidth = texture.getWidth();
float imageHeight = texture.getHeight();
boolean portrait = ((theta / 90) % 2 == 1);
if (portrait) {viewAspect = 1.0f / viewAspect;
}
quad.resizeQuad(viewAspect, u, v, imageWidth, imageHeight);//改变用来贴图片的长方形的大小
quad.bindArrays(gl);//绑定新数据,为渲染做准备。

而位置的改变有两种方式,一种是直接以顶点数据中改变,另一种是计算出在3维3个方向的偏移量,再调用gltranslate来做,从代码可以看出采用的是第二种方式来做的,比第一种方式更方便一些。代码:

Java代码
  1. gl.glTranslatef(-translateXf, -translateYf, -translateZf);
gl.glTranslatef(-translateXf, -translateYf, -translateZf);

而这里的3个偏移量的计算是和camera相关的,相关文件为GridCamera.java,GridCameraManager.java,过程很复杂,理清楚后再细化吧。

cache管理
下面是cache文件

Java代码
  1. /sdcard/Android/data/com.cooliris.media/cache/local-album-cache
  2. d---rwxr-x system   sdcard_rw          2010-05-21 09:56 local-album-cache
  3. d---rwxr-x system   sdcard_rw          2010-05-21 09:56 local-meta-cache
  4. ----rwxr-x system   sdcard_rw   299877 2010-05-28 07:36 local-album-cachechunk_0
  5. d---rwxr-x system   sdcard_rw          2010-05-21 09:56 geocoder-cache
  6. ----rwxr-x system   sdcard_rw      284 2010-05-28 07:36 local-album-cacheindex
  7. d---rwxr-x system   sdcard_rw          2010-05-21 09:56 local-image-thumbs
  8. d---rwxr-x system   sdcard_rw          2010-05-21 09:56 local-video-thumbs
  9. d---rwxr-x system   sdcard_rw          2010-05-21 09:56 picasa-thumbs
  10. ----rwxr-x system   sdcard_rw       80 2010-05-28 07:36 local-meta-cachechunk_0
  11. ----rwxr-x system   sdcard_rw      164 2010-05-28 07:36 local-meta-cacheindex
  12. d---rwxr-x system   sdcard_rw          2010-05-21 09:56 hires-image-cache
  13. ----rwxr-x system   sdcard_rw   627629 2010-05-28 07:37 local-image-thumbschunk_0
  14. ----rwxr-x system   sdcard_rw     3914 2010-05-21 09:56 local-image-thumbsindex
  15. ----rwxr-x system   sdcard_rw    53343 2010-05-28 07:34 hires-image-cache-4982941342287215583_1024.cache
  16. ----rwxr-x system   sdcard_rw   237692 2010-05-28 07:33 hires-image-cache3684568484369117627_1024.cache
  17. ----rwxr-x system   sdcard_rw   133182 2010-05-28 07:34 hires-image-cache607542544081226432_1024.cache
  18. ----rwxr-x system   sdcard_rw    83223 2010-05-28 07:34 hires-image-cache4275479623210216146_1024.cache
  19. ----rwxr-x system   sdcard_rw   292837 2010-05-28 07:34 hires-image-cache-646316556936433937_1024.cache
  20. ----rwxr-x system   sdcard_rw   191377 2010-05-28 07:35 hires-image-cache2631364604509958174_1024.cache
  21. ----rwxr-x system   sdcard_rw   366905 2010-05-28 07:35 hires-image-cache-3280562009766080884_1024.cache
  22. ----rwxr-x system   sdcard_rw   323671 2010-05-28 07:35 hires-image-cache5752471827533329222_1024.cache
/sdcard/Android/data/com.cooliris.media/cache/local-album-cache
d---rwxr-x system   sdcard_rw          2010-05-21 09:56 local-album-cache
d---rwxr-x system   sdcard_rw          2010-05-21 09:56 local-meta-cache
----rwxr-x system   sdcard_rw   299877 2010-05-28 07:36 local-album-cachechunk_0
d---rwxr-x system   sdcard_rw          2010-05-21 09:56 geocoder-cache
----rwxr-x system   sdcard_rw      284 2010-05-28 07:36 local-album-cacheindex
d---rwxr-x system   sdcard_rw          2010-05-21 09:56 local-image-thumbs
d---rwxr-x system   sdcard_rw          2010-05-21 09:56 local-video-thumbs
d---rwxr-x system   sdcard_rw          2010-05-21 09:56 picasa-thumbs
----rwxr-x system   sdcard_rw       80 2010-05-28 07:36 local-meta-cachechunk_0
----rwxr-x system   sdcard_rw      164 2010-05-28 07:36 local-meta-cacheindex
d---rwxr-x system   sdcard_rw          2010-05-21 09:56 hires-image-cache
----rwxr-x system   sdcard_rw   627629 2010-05-28 07:37 local-image-thumbschunk_0
----rwxr-x system   sdcard_rw     3914 2010-05-21 09:56 local-image-thumbsindex
----rwxr-x system   sdcard_rw    53343 2010-05-28 07:34 hires-image-cache-4982941342287215583_1024.cache
----rwxr-x system   sdcard_rw   237692 2010-05-28 07:33 hires-image-cache3684568484369117627_1024.cache
----rwxr-x system   sdcard_rw   133182 2010-05-28 07:34 hires-image-cache607542544081226432_1024.cache
----rwxr-x system   sdcard_rw    83223 2010-05-28 07:34 hires-image-cache4275479623210216146_1024.cache
----rwxr-x system   sdcard_rw   292837 2010-05-28 07:34 hires-image-cache-646316556936433937_1024.cache
----rwxr-x system   sdcard_rw   191377 2010-05-28 07:35 hires-image-cache2631364604509958174_1024.cache
----rwxr-x system   sdcard_rw   366905 2010-05-28 07:35 hires-image-cache-3280562009766080884_1024.cache
----rwxr-x system   sdcard_rw   323671 2010-05-28 07:35 hires-image-cache5752471827533329222_1024.cache

创建cache的关键代码

Java代码
  1. LocalDataSource
  2. public static final DiskCache sThumbnailCache = new DiskCache("local-image-thumbs");----------------------local-image-thumbs local-image-thumbschunk_0  local-image-thumbsindex
  3. public static final DiskCache sThumbnailCacheVideo = new DiskCache("local-video-thumbs");--------------------local-video-thumbs
  4. public static final DiskCache sAlbumCache = new DiskCache("local-album-cache");----------------------local-album-cache  local-album-cacheindex
  5. public static final DiskCache sMetaAlbumCache = new DiskCache("local-meta-cache");------------------local-meta-cache  local-meta-cacheindex
  6. getChunkFile --------------local-meta-cachechunk_0  local-album-cachechunk_0
  7. ReverseGeocoder::  private static final DiskCache sGeoCache = new DiskCache("geocoder-cache"); -------------------------geocoder-cache
  8. PicasaDataSource:: public static final DiskCache sThumbnailCache = new DiskCache("picasa-thumbs");-----------------------------picasa-thumbs
  9. UriTexture::writeToCache  --------------------------hires-image-cache-xxx_1024.cache
LocalDataSource
public static final DiskCache sThumbnailCache = new DiskCache("local-image-thumbs");----------------------local-image-thumbs local-image-thumbschunk_0  local-image-thumbsindex
public static final DiskCache sThumbnailCacheVideo = new DiskCache("local-video-thumbs");--------------------local-video-thumbs
public static final DiskCache sAlbumCache = new DiskCache("local-album-cache");----------------------local-album-cache  local-album-cacheindex
public static final DiskCache sMetaAlbumCache = new DiskCache("local-meta-cache");------------------local-meta-cache  local-meta-cacheindex
getChunkFile --------------local-meta-cachechunk_0  local-album-cachechunk_0ReverseGeocoder::  private static final DiskCache sGeoCache = new DiskCache("geocoder-cache"); -------------------------geocoder-cache
PicasaDataSource:: public static final DiskCache sThumbnailCache = new DiskCache("picasa-thumbs");-----------------------------picasa-thumbs
UriTexture::writeToCache  --------------------------hires-image-cache-xxx_1024.cache

布局补充:
在画一个界面是,是分类化的,比如第一个界面是显示所有有图片的文件夹,在代码里叫专辑.有这些元素要创建:
文本标签  显示专辑名和专辑内图片或视频数
路径条 显示路径名
按纽 拍照按纽,放大/缩小
菜单栏 全选,取消全选,分享,删除,更多等
图片边框
用于显示图片的矩形
在渲染时一次把一类元素画完,再画另一类.如主界面顺序为:
路径条->按纽->文本标签->图片边框->图片.
具体代码见drawBlendedComponents函数

1.CacheService.java 中写缓存: sAlbumCache.put(ALBUM_CACHE_LOCALE_INDEX, sDummyData, 0);

第一个是 key ,这里是正常数据,当然还有别的 key , key 分别是 -1,-2,-3,-4,-5 。

2.DiskCache.java 中,执行上面的写的过程,这里先得明白他的 cache 怎么装的:

它是由很多称之为“片”的文件组成的,形成一个 List 形式: private final

LongSparseArray<RandomAccessFile> mChunkFiles = new LongSparseArray<RandomAccessFile>();

即 mChuckFiles 就是整个 cache ,里面包括很多 chunk( 即片 ) ,每一个 chunk 大小为 1MB.

当要写入某一个 chunk 里面的时候,先要找到他在 mChuckFiles 里面的索引值即 chunkIndex, 由

mChunkFiles.get(chunkIndex); 来获取这个文件, chunkIndex 怎么来的呢?

private LongSparseArray<Record> mIndexMap;

Record record = mIndexMap.get(key); 这里的 key 就是上面用 put 方法传过来的

ALBUM_CACHE_LOCALE_INDEX 的值(就是 -5 )

int chunkIndex = record.chunk;

这么一步步来的。

当然了,第一次都是空的,也就是 get 不到东西 mChunkFiles.get(chunkIndex); 和 Record record =

mIndexMap.get(key); 都 get 不到,那么第一次就先把东西放进去, mIndexMap.put(key, new Record

(chunkIndex, record.offset, data.length, record.sizeOnDisk, timestamp)); (记录 key 值)以及 final

String chunkFilePath = mCacheDirectoryPath + CHUNK_FILE_PREFIX + chunk; chunkFile = new

RandomAccessFile(chunkFilePath, "rw");mChunkFiles.put(chunk, chunkFile); (三句代码来新建一个

chunkfile 并放到 cache 列表里面)

注意: Record 是内部类,只是一个数据集合类而已,相当于文件描述信息。每个 cache (即 chunk )对应一个。

private final LongSparseArray<RandomAccessFile> mChunkFiles = new LongSparseArray<RandomAccessFile>(); 中 mChunkFiles 最大装 13 个,每个 chunk 是 1M, 所以全部 Cache 是 13M.

Gallery3D笔记相关推荐

  1. Android开发_android界面效果全汇总

    (一)Activity页面切换的效果 先介绍下左右滑动切换Activity,对于复杂的手势原理一样,具体后述. 主要原理为监控触屏事件和手势事件,在触屏事件处理函数中调用手势事件处理函数,表示用户触屏 ...

  2. Android界面特殊全汇总

    (一)Activity 页面切换的效果 Android 2.0 之后有了 overridePendingTransition() ,其中里面两个参 数,一个是前一个 activity 的退出两一个 a ...

  3. Gallery3d 学习笔记(13)

    上次我们探讨了Android 4.0中Gallery3d中的视频播放器,现在剩下的代码非常的多,我们先整体看下有那些包 com.android.gallery3d.anim;//动画 com.andr ...

  4. gallery3d源码学习总结(一)——绘制流程drawFocusItems

    eoe·Android开发者门户 标题: gallery3d源码学习总结(一)--绘制流程drawFocusItems [打印本页] 作者: specialbrian    时间: 2010-10-2 ...

  5. 【读书笔记】知易行难,多实践

    前言: 其实,我不喜欢看书,只是喜欢找答案,想通过专业的解答来解决我生活的困惑.所以,我听了很多书,也看了很多书,但看完书,没有很多的实践,导致我并不很深入在很多时候. 分享读书笔记: <高效1 ...

  6. 【运维学习笔记】生命不息,搞事开始。。。

    001生命不息,搞事不止!!! 这段时间和hexesdesu搞了很多事情! 之前是机械硬盘和固态硬盘的测速,我就在那默默的看着他一个硬盘一个机械测来测去. 坐在他后面,每天都能看到这位萌萌的小男孩,各 ...

  7. SSAN 关系抽取 论文笔记

    20210621 https://zhuanlan.zhihu.com/p/353183322 [KG笔记]八.文档级(Document Level)关系抽取任务 共指id嵌入一样 但是实体嵌入的时候 ...

  8. pandas以前笔记

    # -*- coding: utf-8 -*- """ Created on Sat Jul 21 20:06:20 2018@author: heimi "& ...

  9. PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 call

    您的位置 首页 PyTorch 学习笔记系列 PyTorch 学习笔记(六):PyTorch hook 和关于 PyTorch backward 过程的理解 发布: 2017年8月4日 7,195阅读 ...

  10. 容器云原生DevOps学习笔记——第三期:从零搭建CI/CD系统标准化交付流程

    暑期实习期间,所在的技术中台-效能研发团队规划设计并结合公司开源协同实现符合DevOps理念的研发工具平台,实现研发过程自动化.标准化: 实习期间对DevOps的理解一直懵懵懂懂,最近观看了阿里专家带 ...

最新文章

  1. ARM7+PROTEUS调试(转)
  2. CSS HACK:IE6、IE7、IE8、Firefox兼容性问题解决方案
  3. 1.12 foreach循环遍历Collection集合
  4. 学校做计算机教室锐捷,锐捷云课堂:让学生爱上每一节课
  5. Android Gson的使用总结
  6. oracle primavera p6 下载,【项目管理软件套装】Oracle Primavera P6 Enterprise
  7. Linux free 命令详解
  8. mycat两个mysql实例的搭建_Mycat-多实例的搭建
  9. ubuntu上安装python3.7教程_Ubuntu安装python 3. 7
  10. 打印时去除页眉和页脚
  11. 百度直播消息系统的实践和演进
  12. 如何恢复手动删除的微信聊天记录?2个简单高效方法推荐
  13. 华为2019算法大赛CTR预估数据探索
  14. Linux下往github上传项目
  15. IntelliJ IDEA上debug模式启动
  16. BUUCTF-2020寒假刷题记录
  17. 云服务AppId或AppKey和AppSecret生成策略(对外接口使用)
  18. 职场中你是“麦克利兰激励需要理论”中的哪类人
  19. 第十三届蓝桥杯模拟赛(第一期)题解
  20. 为啥IEEE754浮点数尾数用原码不用补码?

热门文章

  1. 关于TOGAF认证考试
  2. C语言小案例_OA大典案例摘录【第1378篇】联想兄弟激光机卡纸 卡定影 有折叠 卡到出纸口不出来 合集...
  3. 考研高等数学张宇30讲笔记——第八讲 一元函数积分学的概念与计算
  4. ojdbc6手动装载
  5. 【2021 年 MathorCup 高校数学建模挑战赛—赛道A二手车估价问题】1 数据分析及可视化
  6. topjui/easyui 表格分页简单实例
  7. modelsim 下载链接
  8. Acad多窗体并排展现
  9. JDE 系统表(标准表)
  10. oracle jde开发,第一个JDE报表开发