热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ViewPager通过PageTransformer实现切换时背景色的渐变

定个小目标我们要实现如下的效果,ViewPager正中的page显示为绿色,其余两边的显示为蓝色。中间page向左右两边切换时会从绿色慢慢过渡到蓝色&

定个小目标

我们要实现如下的效果,ViewPager正中的page显示为绿色,其余两边的显示为蓝色。中间page向左右两边切换时会从绿色慢慢过渡到蓝色,同理两边的page向中间切换时颜色也会慢慢过渡,而不是直接跳变。

PageTransformer

为了实现以上效果我们要借助PagerTransfromer,所以有必要简单介绍下

/*** A PageTransformer is invoked whenever a visible/attached page is scrolled.* This offers an opportunity for the application to apply a custom transformation* to the page views using animation properties.**

As property animation is only supported as of Android 3.0 and forward,* setting a PageTransformer on a ViewPager on earlier platform versions will* be ignored.

*/
public interface PageTransformer {/*** Apply a property transformation to the given page.** @param page Apply the transformation to this page* @param position Position of page relative to the current front-and-center* position of the pager. 0 is front and center. 1 is one full* page position to the right, and -1 is one page position to the left.*/void transformPage(View page, float position);
}

PageTransformer很简单,就只有一个transformPage方法。
第一个参数是我们要变换颜色的page。

重点看第二个参数,英语好的话直接看注释说得很明白,意思就是我们当前要变化的页面当前位置的中心距离pager中心的距离,比如当前处于中心的page的position就是0,右边第一个page的position=1,右边第二个page的position为2,左边第一个page的position=-1,左边第二个page的position=-2,以此类推。

当然position的值不可能一直是整数,比如当处于中间位置的page向右边切换到右边第一个位置时,position的值会从0变化到1,1就是表示一个page的宽度,从中间位置移到右边第一个位置就是移动了一个page的宽度。如果向右移动到一半,那么position就是0.5。

实现的思路

只有中间位置是绿色,其余两边的都是蓝色,所以可以确定的是position=0,肯定是绿色,position的绝对值Math.abs(position)>=1一定是蓝色,剩下的我们就是要处理-1

中间位置到左右两边第一个page的位置的position取绝对值的值范围从0-1,其实就是0%-100%,我们可以用这个值当做颜色的变化率,0就是绿色,值越大表示越往蓝色变化,1就表示变成蓝色了。

另一个难点就是如何实现颜色的渐变。我们知道颜色由RGB表示,有三个颜色的分量分别表示红绿蓝。我们把起始颜色和最终颜色的三个颜色分量分别取出来,分别计算三个颜色分量的差值,最后用差值乘以变化率再加上初始颜色分量就是当前的颜色分量值,把三个当前颜色分量的值拼起来就是当前的颜色值。

初始颜色:#00ff00
最终颜色:#0000ff
初始颜色分量:红00,绿ff(255),蓝00
最终颜色分量:红00,绿00,蓝ff(255)
颜色分量差值:红00,绿-255,蓝255

假设我们要计算position=0.5位置的颜色
当前红色分量=0+0.500=0=0x00
当前绿色分量=255+0.5
(-255)=127=0x7f
当前蓝色分量=0+0.5*255=127=0x7f

所以position=0.5时当前的颜色为#007f7f。

代码实现

一个很简单的功能说了这么多,就是为了让大家更好的理解,如果直接放代码看了坑能会一头雾水

设置PagerTransfromer

mViewPager.setPageTransformer(true, new ViewPager.PageTransformer() {@Overridepublic void transformPage(@NonNull View view, float v) {// 取绝对值v = Math.abs(v);// 超过左右两边第一个位置的page都设置成蓝色if (v > 1) {v = 1;}String color = transColor("#00ff00", "#0000ff", v);view.setBackgroundColor(Color.parseColor(color));}
});

计算当前颜色值

/*** 根据起始颜色、最终颜色和变化率计算当前颜色* @param start 起始颜色* @param end 最终颜色* @param rate 变化率* @return 当前颜色*/
private static String transColor(String start, String end, float rate) {// 获取初始颜色的RGB分量String startR = start.substring(1, 3);String startG = start.substring(3, 5);String startB = start.substring(5, 7);// 获取最终颜色的颜色分量String endR = end.substring(1, 3);String endG = end.substring(3, 5);String endB = end.substring(5, 7);// 计算初始颜色的RGB分量十进制值int startRI = Integer.parseInt(startR, 16);int startGI = Integer.parseInt(startG, 16);int startBI = Integer.parseInt(startB, 16);// 计算最终颜色的RGB分量十进制值int endRI = Integer.parseInt(endR, 16);int endGI = Integer.parseInt(endG, 16);int endBI = Integer.parseInt(endB, 16);// 计算当前颜色分量int curRI = (int) (startRI + (endRI - startRI)*rate);int curGI = (int) (startGI + (endGI - startGI)*rate);int curBI = (int) (startBI + (endBI - startBI)*rate);// 转成16进制String curR = String.format("%02x", curRI);String curG = String.format("%02x", curGI);String curB = String.format("%02x", curBI);// 拼成颜色码return "#" + curR + curG + curB;
}

如果喜欢我的文章,可以扫描以下二维码关注我的微信公众号,我会定期发布最新的文章。
关注我的微信,回复背景色渐变获取本文的完整代码。


推荐阅读
  • 拥抱Android Design Support Library新变化(导航视图、悬浮ActionBar)
    转载请注明明桑AndroidAndroid5.0Loollipop作为Android最重要的版本之一,为我们带来了全新的界面风格和设计语言。看起来很受欢迎࿰ ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 如何自行分析定位SAP BSP错误
    The“BSPtag”Imentionedintheblogtitlemeansforexamplethetagchtmlb:configCelleratorbelowwhichi ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • sklearn数据集库中的常用数据集类型介绍
    本文介绍了sklearn数据集库中常用的数据集类型,包括玩具数据集和样本生成器。其中详细介绍了波士顿房价数据集,包含了波士顿506处房屋的13种不同特征以及房屋价格,适用于回归任务。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • Android JSON基础,音视频开发进阶指南目录
    Array里面的对象数据是有序的,json字符串最外层是方括号的,方括号:[]解析jsonArray代码try{json字符串最外层是 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 成功安装Sabayon Linux在thinkpad X60上的经验分享
    本文分享了作者在国庆期间在thinkpad X60上成功安装Sabayon Linux的经验。通过修改CHOST和执行emerge命令,作者顺利完成了安装过程。Sabayon Linux是一个基于Gentoo Linux的发行版,可以将电脑快速转变为一个功能强大的系统。除了作为一个live DVD使用外,Sabayon Linux还可以被安装在硬盘上,方便用户使用。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
author-avatar
铁人萱小小
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有