位置: 编程技术 - 正文

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怎么用)

  • 含13%的增值税怎么算
  • 增值税抵扣了还能作废吗
  • 个人可以申请代收货款吗
  • 临时用工的会计分录
  • 食用油交不交消费税
  • 企业间无偿划转会计分录
  • 社保扣款上月没扣本月如何做会计处理?
  • 补交以前年度印花税记到哪个会计科目
  • 法人的投资款如何拿出来
  • 企业赞助学校发言稿
  • 收到补助款的会计分录
  • 公司注销后如何申请强制执行
  • 资管产品征税
  • 借款利息不能抵扣进项税
  • 未及时申报个税的理由
  • 设备销售和安装账务
  • 供应商返点抵应怎么做账
  • 总公司资金转入私人账户
  • 投资活动净现金流为负说明什么
  • 事业单位接受捐赠的货币资金在财务会计中确认捐赠收入
  • 银行余额调节表的作用
  • 物业公司成本结转方案
  • ajax请求php接口
  • 企业的往来账款包括哪些
  • 财产损失立案
  • 分期摊销法计算公式
  • php生成二维码源码
  • 公司出租房屋租赁发票税率
  • 从事广告代理业工作
  • vue 网页
  • 用人单位未为劳动者缴纳社会保险费
  • 商品入库进项税额怎么算
  • 没进项可以开专票吗
  • php框架有哪些官网
  • 营改增企业所得税税率
  • js数组方法大全
  • 【深度学习】详解 MoCo
  • php动态语言
  • php过滤html
  • 公司的车的停车费谁出
  • 运输发票的抵扣期限
  • 歌咏比赛服装费用规定标准最新
  • 环保税的算法
  • 未达起征点免税额怎么计算
  • 个税申报系统非正常可以改为正常吗?
  • 小规模公司购买汽车会计分录
  • 完税凭证抵扣进项税额分录
  • 进项税和销项税月末怎么结转
  • 滴滴打车老板起源故事
  • 投资收益的会计科目
  • 简易计税开具的发票取得的进项可以抵扣嘛
  • 股东追加投资怎么算
  • 企业利润分配应当遵循的原则
  • 投资性房地房地产
  • 固定资产的税法处理与会计处理的差异50字
  • 快递公司的主营业务范围
  • 什么叫社保差额调整
  • 固定资产改变用途折旧处理
  • mysql全部语法
  • linux 清理
  • wrsvn.exe是什么
  • win10预览版选哪个
  • window10路由
  • win8系统怎么设置无线网连接啊
  • 好好了解 英文
  • 微信小程序使用webview
  • js函数详解
  • 批处理设置dns
  • Host 'admin-PC' is not allowed to connect to this MySQL server
  • unity strangeioc
  • jquery动画效果代码
  • JavaScript 事件绑定及深入
  • 安卓手机如何查
  • bootstrap要学到什么程度
  • 深圳税务网上申报客户端更正申报流程
  • 武汉 税务局
  • 智行火车票电子报销凭证
  • 稽查局是税务局的派出机构还是内设机构
  • 税务行业微信缴税项目是什么消费
  • 国税申报时间2023年10月
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设