位置: 编程技术 - 正文

Cocos2dx3.2编写常用UI组件(二)滚动计数器NumberScroller(cocos2dx怎么用)

编辑:rootadmin

推荐整理分享Cocos2dx3.2编写常用UI组件(二)滚动计数器NumberScroller(cocos2dx怎么用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:cocos2dx schedule,cocos用什么写代码,cocos代码,cocos编程语言,cocos2d schedule,cocos2djs,cocos编程,cocos2djs,内容如对您有帮助,希望把文章链接给更多的朋友!

前言:

废话不多说,先看最终效果图

正文:

1、使用说明:

①引入头文件 “NumberScroller.h"

②用NumberScroller::create(int length,int fontSize) 函数来创建NumberScroller对象

③利用setNumber(int number)函数来设置计时器里面的&#;(这里只实现了向后滚动,即设置的&#;要大于等于当前&#;)

④利用getNumber获得当前计数器显示的&#;

⑤利用setTime(float time)函数来设置计时器滚动的速度,默认为1

2、实现思路:

①根据输入的长度length确定计时器的长度(即多少位)

②根据输入的fontSize确定字体大小

③创建length条并排放置的竖着的从(注意末尾有个零)

④根据设置的数字,不同的竖条移动相应的位置。

⑤利用遮罩层遮罩

3、源码解析:

对应思路①②

先暂时不用看设置遮罩层部分,前面只是保存长度和字体大小到成员变量中,下面的一个for循环就是用来排好length列数字的

其中这里出现了一个NumberColumn类,表示一列数字

具体的初始化函数如下

Cocos2dx3.2编写常用UI组件(二)滚动计数器NumberScroller(cocos2dx怎么用)

NumberColumn的init函数里面,除了保存长度和字体大小和启动update外,接下来就是构造一个的竖列

注意,我们这里把所有Label都放在一个Node里面,这样可使我们更方便的操作

最后,回到NumberScroller 初始化完的效果是这样子(无遮罩)的:

NumberScroller最重要的函数还是setNumber

可以看出都是间接地调用NumberColumn的setNumber方法

奇怪啦,NumberColumn也只是简单的把传来的number保存到m_target_num里面,还有计算滚动的速度 也没有实现滚动的动作啊

奥秘在于NumberColumn启动的update函数

update函数便是实现滚动效果的核心,每一行都给了详细的注释

因为我们这里要实现的是类&#;于时钟的滚动效果(秒针转1圈时,分针转1/圈),应用到计时器,个位滚动次,十位才会转一下

所以对应每一条NumberColum,其对应的m_cur_num是不一样的。

例如这个数 ,第一条(百位)对应的m_cur_num应该是9,第二条(十位)对应的m_cur_num应该是,第三条(个位)对应的m_cur_num应该是

由于setNumber时候计算了速度:

间隔越大,速度越快,因此保证了每条NumberColumn均会在m_time时间内完成滚动

有了上面的介绍,再回过头来再看一次NumberScroller的setNumber函数,是不是恍然大悟呢

完成效果后如下:

最后,添加遮罩层,只显示当前数字部分。

关于遮罩的基本知识,推荐一个很好的blog

Cocos2dx3.2编写常用UI组件(三)收集器效果Collector 前言:在游戏中,我们经常可以看到,获取分数后,分数会自动升到对应的分数栏上面。今天我们就来实现这种效果正文:这种效果实现起来其实非常

Cocos2dx3.2编写常用UI组件(四)发光的标题BlinkTitile 前言:如果看了上一节我推荐的blog,并且掌握了遮罩层的运用,那么本节介绍的发光标题就非常的简单了。没有看也没关系,现在我来具体讲一下Clippin

cocos2dx中的AndroidManifest.xml文件详解 原创作品,允许转载,转载时请务必以超链接形式标明文章原始出处、作者信息和本声明。否则将追究法律责任。

标签: cocos2dx怎么用

本文链接地址:https://www.jiuchutong.com/biancheng/372733.html 转载请保留说明!

上一篇:qt+creator 轻松搭建cocos2dx开发环境(qt creator kit)

下一篇:Cocos2dx3.2编写常用UI组件(三)收集器效果Collector(cocos2d怎么用)

  • 农产品收购发票使用范围
  • 一般纳税人开普票和专票有什么区别
  • 公司破产债务清偿顺序是怎样的
  • 公司福利可以抵扣所得税吗
  • 每个月结转损益都有什么科目
  • 车间职工报销医药费能使用现金吗
  • 或有负债在报表附注哪里
  • 固定资产可以计入实收资本吗
  • 合同解除收取对方的违约金交什么税
  • 贷款应计利息会计分录
  • 工程设备租赁带什么手续
  • 报关单不存在
  • 购进商品返点的钱用于抵扣货款怎么入账?
  • 企业所得所得税税负
  • 小微 小型微利
  • 销售退回发票怎么处理
  • 物业公司广告位出租怎么入账
  • 工会经费什么时候返还给企业
  • 建筑安装预缴增值税
  • 劳务工资要附什么合同
  • 工商企业年报网上申报时间
  • cookie 区别
  • php composer自动加载
  • 出租商品计入其他业务收入吗
  • PHP:pg_fetch_object()的用法_PostgreSQL函数
  • PHP:proc_get_status()的用法_命令行函数
  • 前端vue后端node
  • 预收的购货款属于收入吗
  • 前端uniapp写表格
  • 去噪扩散概率模型
  • php数据导出到excel
  • 建筑工程增值税怎么算
  • 预提借款税费会减少吗
  • es6解构赋值对象
  • php对象是什么类型的数据
  • 有形动产的租赁增值税税率是多少
  • system error
  • 个人所得税年度申报什么意思
  • 现金流量表和资产负债表的区别
  • python __call__
  • 应付利息如何结转
  • 公司购买空调计入什么费用
  • 个税补缴纳
  • 无票收入如何报税
  • 固定资产折旧常见方法
  • 银行汇票用什么会计分录
  • 应付利息的账务处理
  • 社保比例调整了吗
  • 交易性金融资产公允价值变动怎么算
  • 商家的促销
  • 预收账款怎么用
  • 票据质押如何做账
  • 个人独资企业个体工商户的区别
  • 哪些收入不需要开票
  • 定额发票怎么领?
  • 暂估入库后发票来不了会计分录
  • 一般纳税人暂估入库的会计分录怎么写
  • 应交税金借方余额在报表列示
  • 企业积分是什么意思
  • linux 更新系统
  • win7系统共享打印机设置方法
  • win8怎么查看隐藏文件
  • win7怎么设置局域网共享文件和操作
  • 安卓手机好用的笔记类app
  • 及将上市的手机
  • python输出代码怎么写
  • android studio环境
  • android怎么样
  • unity-
  • nodejs bff
  • javascript简单
  • javascript的
  • JavaScript入门教程
  • staticlayout 换行
  • 抵扣怎么做账
  • 什么是增值税免抵税额
  • 出口退税申报时闿
  • 企业卖旧房如何计算缴纳土地增值税
  • 深圳海关属于省级吗
  • 发票挂失费用
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设