android仿淘宝刮刮卡功能实现

简介:

去年淘宝和天猫的活动搞的有声有色的,其中有一个游戏还是很受大家欢迎的,那就是红包刮刮卡,自己也挺迷的,一刮起来就停不下来,有没有?

最近自己也在学习android入门,正好前些日子在搜索一个功能示例的时候,找到一个哥们分享的一篇介绍刮刮卡的文章,文章很简单,基本没有废话,直接贴了如何通过自定义view来实现刮刮卡的示例代码,链接如下:

http://www.cnblogs.com/xinye/p/3616095.html

 

后来又借着给大家分享android开发入门知识的机会,以这个示例为主要功能参考,并主要仿照天猫红包刮刮卡的外观样式和交互功能,做了一个还算功能齐全的示例,因为主要是为了讲解,所以特意把注释标注的比较完整,大家可以通过下面的链接到我共享的列表中下载示例源码:

https://github.com/yangguilin/GuaGuaLe

 

下面简单分析一下,实现刮刮卡功能的几点关键知识点:

1. 自定义一个View子类(TextView当然也可以,俺就是用得TextView做父类),并且重写下面几个主要方法:

(1) 构造函数

(2)视图绘制方法:protected void onDraw(Canvas canvas)

(3) 触屏事件处理方法:public boolean onTouchEvent(MotionEvent event)

 

2. 第一步中的三个方法是主要且必须的三个方法,接下来,在构造函数中,需要添加初始化刮刮卡视图的功能,该功能可以分解为以下几个关键步骤:

(1) 设置视图背景图片:因为涉及到随机变换的是否中奖的图片,所以意味着这个背景需要通过canvas来操作bitmap来做一次简单的绘制,首先为bitmap设置一种背景色,然后再通过canvas将得到的,需要显示的图片,根据具体的尺寸比例,画到bitmap中即可。

(2) 视图背景搞定后,接下来要搞定的就是刮刮卡的涂层,也就是咱们能用手指划掉的那一层,原理基本类似于背景,首先创建一个topBitmap,然后将该topBitmap载入到一个Canvas中进行编辑,为该topBitmap添加一层灰色的背景色,然后再通过定义一个画笔,再在该topBitmap上绘制上提示文字“请刮开涂层”,这样刮刮卡的所谓上下两层均已经定义完毕。

(3) 接下来,需要定义一只手指划到涂层时,来绘制透明色的画笔,其工作原理主要就是,通过调用默认的触屏事件 + 视图自动绘制,来实现所谓的手指刮开涂层的操作。(这部分也是不太容易理解的,或许是我说不清楚,总之看代码注释吧,会比较清楚)

(4) 此外,如何实现当手指划开大部分背景图片时,自动去除全部涂层,说来也挺简单,不排除有更完美的处理方案,俺用的是关键点法,即定义若干(示例中定义了9个)关键点,分布于待显示的背景图的主要区域,然后在每一次判断手指滑动的事件的同时,顺便检查是否有大多数的关键点的颜色值已经变为了透明(颜色值为0,即已被刮开),如果是,则通过canvas直接将topBitmap的颜色统一设置为透明色即可。

(5) 针对不同尺寸的android手机,如何做到显示一致?这也是一个后期的主要问题,因为前期通过不断调试,设定的一些尺寸,都是基于调试机的,既然要在各种不同版本、品牌的机器上运行,那么适配就是一个主要的问题,我是用了一种比较偷懒的方法,及将调试机的各项参数数据作为默认的参数,然后每次初始化的时候,都会获取当前屏幕的分辨率尺寸,然后与默认值的屏幕宽度进行比较,得到一个比例,然后在所有需要明确使用数值的地方,都乘以该比例,间接地达到了对试图缩放的目的。

 

最后,附上两张示例的截图:

Screenshot_2014-04-02-19-21-22    Screenshot_2014-04-02-19-21-43

 

Screenshot_2014-04-02-19-22-16     Screenshot_2014-04-02-19-21-51

相关文章
|
8月前
|
XML 缓存 Android开发
Android开发,使用kotlin学习多媒体功能(详细)
Android开发,使用kotlin学习多媒体功能(详细)
168 0
|
3月前
|
Android开发
Android开发表情emoji功能开发
本文介绍了一种在Android应用中实现emoji表情功能的方法,通过将图片与表情字符对应,实现在`TextView`中的正常显示。示例代码展示了如何使用自定义适配器加载emoji表情,并在编辑框中输入或删除表情。项目包含完整的源码结构,可作为开发参考。视频演示和源码详情见文章内链接。
82 4
Android开发表情emoji功能开发
|
3月前
|
安全 Android开发 iOS开发
Android vs iOS:探索移动操作系统的设计与功能差异###
【10月更文挑战第20天】 本文深入分析了Android和iOS两个主流移动操作系统在设计哲学、用户体验、技术架构等方面的显著差异。通过对比,揭示了这两种系统各自的独特优势与局限性,并探讨了它们如何塑造了我们的数字生活方式。无论你是开发者还是普通用户,理解这些差异都有助于更好地选择和使用你的移动设备。 ###
61 3
|
5月前
|
编解码 测试技术 Android开发
Android经典实战之用 CameraX 库实现高质量的照片和视频拍摄功能
本文详细介绍了如何利用CameraX库实现高质量的照片及视频拍摄功能,包括添加依赖、初始化、权限请求、配置预览与捕获等关键步骤。此外,还特别针对不同分辨率和帧率的视频拍摄提供了性能优化策略,确保应用既高效又稳定。
468 1
Android经典实战之用 CameraX 库实现高质量的照片和视频拍摄功能
|
4月前
|
Android开发 开发者
Android平台无纸化同屏如何实现实时录像功能
Android平台无纸化同屏,如果需要本地录像的话,实现难度不大,只要复用之前开发的录像模块的就可以,对我们来说,同屏采集这块,只是数据源不同而已,如果是自采集的其他数据,我们一样可以编码录像。
|
5月前
|
图形学 Android开发
小功能⭐️Unity调用Android常用事件
小功能⭐️Unity调用Android常用事件
|
7月前
|
数据库 Android开发 数据安全/隐私保护
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
在 Android Studio 中结合使用 SQLite 数据库实现简单的注册和登录功能
295 2
|
7月前
|
Android开发
Android中如何快速的实现RecycleView的拖动重排序功能
使用`ItemTouchHelper`和自定义`Callback`,在`RecyclerView`中实现拖动排序功能。定义`ItemTouchHelperAdapter`接口,`Adapter`实现它以处理`onItemMove`方法。`SimpleItemTouchHelperCallback`设置拖动标志,如`LEFT`或`RIGHT`(水平拖动),并绑定到`RecyclerView`以启用拖动。完成这些步骤后,即可实现拖放排序。关注公众号“AntDream”获取更多内容。
129 3
|
8月前
|
移动开发 监控 Android开发
构建高效Android应用:从内存优化到电池寿命代码之美:从功能实现到艺术创作
【5月更文挑战第28天】 在移动开发领域,特别是针对Android系统,性能优化始终是关键议题之一。本文深入探讨了如何通过细致的内存管理和电池使用策略,提升Android应用的运行效率和用户体验。文章不仅涵盖了现代Android设备上常见的内存泄漏问题,还提出了有效的解决方案,包括代码级优化和使用工具进行诊断。同时,文中也详细阐述了如何通过减少不必要的后台服务、合理管理设备唤醒锁以及优化网络调用等手段延长应用的电池续航时间。这些方法和技术旨在帮助开发者构建更加健壮、高效的Android应用程序。
|
6月前
|
Android开发
Android自定义之高仿淘宝下拉刷新
Android自定义之高仿淘宝下拉刷新
89 0