android自动画廊,Android3D画廊效果与自动轮播Banner

android自动画廊,Android3D画廊效果与自动轮播Banner最开始项目需要使用3D画廊效果作为首页轮播,网上找了半天也没有比较满意的,最终决定自己写一个。本控件采用的是viewpager完成的,支持无限滑动的3D视觉的画廊效果、平面普通广告栏轮播。提供对外方法:指示器图片自定义、小图片位置、是否圆角等。本代码已托管到[github]https://github.com/lzjin/ViewPagerGallery1、先看效果图:gif1.gifgif2….

大家好,又见面了,我是你们的朋友全栈君。

最开始项目需要使用3D画廊效果作为首页轮播,网上找了半天也没有比较满意的,最终决定自己写一个。本控件采用的是viewpager完成的,支持无限滑动的3D视觉的画廊效果、 平面普通广告栏轮播。提供对外方法:指示器图片自定义、小图片位置、是否圆角等。本代码已托管到[github]https://github.com/lzjin/ViewPagerGallery

1、先看效果图:

0f07ba318f1c

gif1.gif

0f07ba318f1c

gif2.gif

0f07ba318f1c

ic_banner3.png

0f07ba318f1c

ic_banner1.png

0f07ba318f1c

ic_banner2.png

2、效果分析 3D画廊效果

代码调用:

mViewPager.initBanner(imagesUriList, true)//图片地址,isGallery参数是否开启3D画廊效果

.addPageMargin(10, 50)//参数1page之间的间距,参数2中间item距离边界的间距

.addPoint(6)//添加指示器

.addPointBottom(7)

.addStartTimer(5)//自动轮播5秒间隔

.addRoundCorners(12)//圆角

.finishConfig()//这句必须加

.addBannerListener(new BannerViewPager.OnClickBannerListener() {

@Override

public void onBannerClick(int position) {

//点击item

}

});

代码分析:

3D画廊效果,是通过滑动的属性动画来设置。那我们就得就得了解ViewPager的PageTransformer类。重写PageTransformer,在滑动的时候进行X轴、Y轴的缩放拉伸来实现。

(1)(-oo,-1) 相对于左边第一页,其左边的所有页面

if (position < -1) {

view.setScaleX(MIN_SCALE);

view.setScaleY(MIN_SCALE);

view.setAlpha(MIN_ALPHA);//这里是设置透明度

}

(2)[-1, 1 )当前页的左右第一页

else if (position < 1) {

float scaleFactor = MIN_SCALE + (1 – Math.abs(position)) * (MAX_SCALE – MIN_SCALE);

//[0, 1 ) 相对于当前选中页,其右边第一页 **

if (position > 0) {

view.setTranslationX(-scaleFactor);

}

// [-1, 0 ) 相对于当前选中页,其左边的第一页**

else if (position < 0) {

view.setTranslationX(scaleFactor);

}

view.setScaleY(scaleFactor);

view.setScaleX(scaleFactor);

// float alpha = 1f – Math.abs(position) * (1 – );

float alpha = MIN_ALPHA + (1 – MIN_ALPHA) * (1 – Math.abs(position));

view.setAlpha(alpha);//透明度

}

(3)[1,+oo) 相对于右边第一页,其右边的所有页面

// (1,+Infinity]

else {

view.setScaleX(MIN_SCALE);

view.setScaleY(MIN_SCALE);

view.setAlpha(MIN_ALPHA);//透明度

}

(4)为了让界面显示3item数据,设置左右间距,这里要注意以下 android:clipChildren=”false” 这句代码的含义,就是不限制View的布局,已达到边界绘制效果。(间距根据自己需要可更改)

android:id=”@+id/viewPager”

android:layout_width=”match_parent”

android:layout_height=”wrap_content”

android:clipChildren=”false”

android:layout_marginLeft=”60dp”

android:layout_marginRight=”60dp”/>

(5)圆角设置

由于网络图片加载我用的Glide库,对应的圆角设置重写BitmapTransformation即可。这里不多讲,网上工具类很多。

//自定义圆角

public class CornerTransform extends BitmapTransformation {

private static float radius = 0f;

public CornerTransform(Context context) {

this(context, 4);

}

public CornerTransform(Context context, int dp) {

super(context);

this.radius = Resources.getSystem().getDisplayMetrics().density * dp;

}

@Override protected Bitmap transform(BitmapPool pool, Bitmap toTransform, int outWidth, int outHeight) {

return roundCrop(pool, toTransform);

}

private static Bitmap roundCrop(BitmapPool pool, Bitmap source) {

if (source == null) return null;

Bitmap result = pool.get(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_8888);

if (result == null) {

result = Bitmap.createBitmap(source.getWidth(), source.getHeight(), Bitmap.Config.ARGB_8888);

}

Canvas canvas = new Canvas(result);

Paint paint = new Paint();

paint.setShader(new BitmapShader(source, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP));

paint.setAntiAlias(true);

RectF rectF = new RectF(0f, 0f, source.getWidth(), source.getHeight());

canvas.drawRoundRect(rectF, radius, radius, paint);

return result;

}

@Override public String getId() {

return getClass().getName() + Math.round(radius);

}

}

3、 普通效果2

跟上面的实现差不多,唯一的区别就是不重写PageTransformer,参数设置false,使用系统默认的滑动效果即可。

mViewPager.initBanner(imagesUriList, false)//图片地址,关闭3D画廊效果

.addPageMargin(10, 50)//参数1page之间的间距,参数2中间item距离边界的间距

.addPoint(5)//添加指示器,5dp

.addPointBottom(7)

.addStartTimer(5)//自动轮播5秒间隔

.addRoundCorners(12)//圆角

.finishConfig()//这句必须加

.addBannerListener(new BannerViewPager.OnClickBannerListener() {

@Override

public void onBannerClick(int position) {

//点击item

}

});

4、 普通效果1

在普通效果2上,少了圆角设置,已经左右间距设置0即可。

mViewPager.initBanner(imagesUriList, false)//图片地址,关闭3D画廊效果

.addPageMargin(0, 0)//无间距

.addPoint(5)//添加指示器,5dp

.addPointBottom(7)

.addStartTimer(5)//自动轮播5秒间隔

.finishConfig()//这句必须加

.addBannerListener(new BannerViewPager.OnClickBannerListener() {

@Override

public void onBannerClick(int position) {

//点击item

}

});

5、 方法讲解

initBanner(List imagesUriList,boolean isGallery)//图片,是否开启3D画廊效果

initBanner(List imagesUriList,boolean isGallery,float alpha)//图片,画廊,alpha透明度

addPoint(int distance) //间距

addPoint(int distance,int piont_press,int piont) //间距、选中小圆点自定义、未选中小圆点自定义

addRoundCorners(int corners)//圆角10dp

addStartTimer()、stopTimer()

addDefaultImg()

//注意:当添加了3D画廊效果时,columnMargin尽量设小。应该本是已经进行了x、y的缩放

addPageMargin(int columnMargin,int rowMargin)//两个Page之间的距离,中间item的对边界的边距

6.结尾

因为是网络图片,请加网络权限。

如果还是有什么不懂,请前往github查看源码。

纯手工写,实属不易,各位看官如果本文对你有帮助,请点个赞吧。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/137939.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • intellij idea最新版安装步骤_学生用idea用哪个版本好

    intellij idea最新版安装步骤_学生用idea用哪个版本好1、首先在官网上面下载idea网址:https://www.jetbrains.com/idea/2、选择下载DownLoad3、下载可能需要注册,不需要理会,等待下载界面出来就行了4、双击下载好的ideaIU-2018.3.4.exe文件,选择next5、自定义设置安装目录6、按照下面的勾选就行了7、点击install,等待安装成功就行了…

    2022年10月2日
    3
  • pycharm需要安装哪些库_python编程

    pycharm需要安装哪些库_python编程好久没用python,竟然连怎么在Pycharm新建项目都忘了…????(。﹏。*)项目解释器选择自带的python还是自动创建虚拟环境还是使用Anaconda里面的虚拟环境

    2022年8月28日
    5
  • NB-IoT应用场景_iot框架

    NB-IoT应用场景_iot框架NB-IOT实现万物互联设计思路分享(固定上报类)NB-IOT窄带物联网(NarrowBandInternetofThings,NB-IoT),是一种专为万物互联打造的蜂窝网络连接技术。NB-IOT作为近年大火的一项物联网技术,因为其特性受到了众多行业众多企业的青睐。其广覆盖,大连接,低功耗,低成本的四大主要特点符合众多行业的实现物联网平滑过度的要求,成为了物联网技术又一代宠儿。本人也…

    2022年9月26日
    3
  • 怎么让Linux发邮件? Linux怎么发email

    怎么让Linux发邮件? Linux怎么发email相比大家也想让自己的Linux备份啊什么的存储起来  放到哪里最安全呢 相比来说放到自己QQ邮箱比放到自己电脑更安全一些我们今天就来做一个实验让你的Linux发邮件到你的mail中我们今天需要一个软件(mailx)直接yum装即可:yuminstall-ymailx 然后我们创建一个隐藏文件类似.sh 随便一个就好 vi/email.sh然…

    2022年10月20日
    3
  • 学习笔记之Python 3[通俗易懂]

    学习笔记之Python 3[通俗易懂]学习笔记之Python 3

    2022年4月22日
    41
  • Python第七章-面向对象高级

    Python第七章-面向对象高级面向对象高级一、特性特性是指的property.property这个词的翻译一直都有问题,很多人把它翻译为属性,其实是不恰当和不准确的.在这里翻译成特性是为了和属性区别开来.属性是指的

    2022年7月6日
    19

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号