码迷,mamicode.com
首页 > 移动开发 > 详细

Android 打造炫酷的3D画廊

时间:2021-01-01 12:28:14      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:滑动   pager   oid   return   缓存   cli   child   id3   ntp   

技术图片
本文由戎码之路投稿。

戎码之路的博客地址:

http://www.cnblogs.com/libertycode/

网上有很多关于使用Gallery来打造3D画廊的博客,但是在关于Gallery的官方说法中表明:

This class was deprecated in API level 16.

于是我就在想,既然如此,那就用ViewPager来写一个吧,于是就有了这篇博客!

进入正题:

要实现如下图的功能,需要以下几点:

  1. 使用ViewPager

  2. 设置PageTransformer

  3. 获取图片倒影

技术图片

1 ViewPager的使用

先来简单了解一下PagerAdapter的使用
要实现PagerAdapter,必须至少实现以下四个方法:

  1. public int getCount()

  2. public Object instantiateItem(ViewGroup container, int position)

  3. public void destroyItem(ViewGroup container, int position, Object object)

  4. public boolean isViewFromObject(View view, Object object)

 

方法解释: 

getCount方法就不用说了,实现过BaseAdapter的童鞋应该知道的,就是用来放回当前List中的Page数量的。

  

instantiateItem方法,这个方法是负责向ViewGroup也就是ViewPager中添加新的页面,并返回一个继承自Object的key,这个key将会在第三个方法destroyItem和第四个方法isViewFromObject中作为参数调用。


@Override
public Object instantiateItem(ViewGroup container, int position) {
    ImageView imageView=imageViewList.get(position);
    container.addView(imageView,position);
    return imageView;
}

destroyItem方法负责从ViewGroup中移除对应position中的page


@Override
public void destroyItem(ViewGroup container, int position, Object object) {
    container.removeView(imageViewList.get(position));
}

isViewFromObject确定instantiateItem返回的特定key 对象是否与page View有关联。由于instantiateItem中可以以自身page为key返回,所以在这里就可以这样写:


@Override            
public boolean isViewFromObject(View view, Object object) {   
    return view==object;
}

ViewPager作为布局管理器,非常强大,也可以用来展示Fragment,当然adapter需要使用FragmentPagerAdapter或者FragmentStatePagerAdapter。

2 设置PageTransformer

PageTransformer是ViewPager的一个公共成员接口,用于设置当一个页面滑入和滑出的过度特效,当然,由于是通过属性动画来设置的,所以设置的pagetransformer在Android3.0以下会被忽略。

关于实现该接口,只需要实现一个方法即可:

  public void transformPage(View page, float position);

对于参数position,需要好好说明一下:

position的取值有如下说明:

position是指的是页面相对于中间页面的位置参数,根据位置不同,0的时候在中间最前面,1的时候页面完全在右边,-1的时候页面完全在左边。如下图所示:
技术图片
关于该接口的更多知识可以看鸿洋大大的这篇博客:http://blog.csdn.net/lmj623565791/article/details/40411921/

那么要实现上面的效果要怎么做呢?

代码如下:

技术图片
然后:


viewPager.setPageTransformer(true,new MyTransformation()); 

效果如下:

技术图片
诶,和前面给出的效果图不一样啊,为什么呢?一开始我也不明白,后来在网上查阅资料,找到了如下方法:

(1)为解决不在ViewPager中间页面被剪掉的问题:

需要在ViewPager和其父容器中设置clipChildren为false

技术图片
(2)为解决触摸滑动ViewPager左右两边的页面无反应的问题:

 

需要为ViewPager的父容器设置OnTouchListener,将触摸事件传递给ViewPager
技术图片
效果如下:

技术图片
3 获取图片倒影

代码如下:

技术图片
恩,在实际使用上述代码的时候,尽可能考虑不要频繁创建过多的对象,以及对于倒影图也可以通过软引用的方式进行缓存。

参考自http://blog.csdn.net/lovoo/article/details/51591580

最终效果:

技术图片
源码下载:

https://github.com/liberty2015/3DViewPagerGallery

如果你有好的文章想和大家分享,欢迎投稿,直接向我投递文章链接即可。

欢迎长按下图->识别图中二维码或者扫一扫关注我的公众号:

技术图片

阅读原文

Android 打造炫酷的3D画廊

标签:滑动   pager   oid   return   缓存   cli   child   id3   ntp   

原文地址:https://blog.51cto.com/15064646/2575313

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!