位置: 编程技术 - 正文

cocos2dx之TableView和ScrollView的混合使用(cocos2d-js-min.js)

编辑:rootadmin

推荐整理分享cocos2dx之TableView和ScrollView的混合使用(cocos2d-js-min.js),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:cocos2d官网,cocos 2,cocos webgl,cocos2dx官方教程,cocos2d html5,cocos 2,cocos2d官网,cocos2d html5,内容如对您有帮助,希望把文章链接给更多的朋友!

**************************************************************************

时间:--

作者:Sharing_Li

转载出处:

玩过《开心消消乐》这款游戏的人,应该知道里面有这样一处设计,如下图:

我们可以左右滑动界面,也可以上下滑动界面,左右滑动的时候不能上下滑动,上下滑动的时候不能左右滑动。这种效果可以用TableView和ScrollView来组合实现,即先弄一个ScrollView,然后把2个TableView当作内容放入这个ScrollView中就可以了,这种UI设计也应用在《开心消消乐》其好友信件中,只不过多了一个TableView。

接下来将进行代码讲解,cocos2dx的版本是3.2,先展示一下实现之后的效果图:

看完效果图,再看正文,定义一个类:CombineView

头文件:CombineView.h

再看看cpp文件的实现,这里对主要的代码进行讲解,想要完整代码和资源,请到文章末尾点击下载(0下载积分)。

我们写代码,要养成初始化成员变量的习惯,这样可以避免一些意想不到的错误。同时记住不用的资源要记得释放。

cocos2dx之TableView和ScrollView的混合使用(cocos2d-js-min.js)

如效果图所示,我们要搞一个scrollview,这家伙呢,怀了5个月的三胞胎,分别是三个tableview。为了区别这三个儿子(喂,你怎么知道都是男的而不是女的),我们要给他们取名字,因为他们仨要共用一个函数即tableCellAtIndex,如果不取名,怎么知道谁是老二老三呢, 如头文件中定义的枚举类。

然后我们再来看看触摸函数的实现,首先是touchbegan:

简洁明了(.......),然后再看touchmoved:

这一段代码的意思是:如果你先垂直滑动,那么就将m_vertical设置为true,这样你就不能水平滑动了;如果你先水平滑动,就将m_horizontal设置为true,因而调用函数SetTouch,对着三个孩子tableview唱摇篮曲,要他们乖乖睡觉不要乱动。然后再来看看touchended:

这一段代码的意思是:if (fabsf(distance) < )这个if语句是对滑动效果的优化,如果滑动很小距离,那么就忽视这次滑动,视图还是老样子,效果图如下:

这下应该一目了然了吧,接下来的代码是判断是先垂直滑动还是水平滑动,如果是先垂直,则直接return,return之前呢要还原m_curPage的&#;。如果是先水平,则要把三个熟睡的孩子搞醒。然后是对scrollview最终显示界面的调整:

未列出的部分代码如下:

最后,完了。。。。。。。。。。才怪!

代码其实有问题,我故意留了一个bug,不知道大家发现没,这个bug不解决的话,程序跑起来会崩溃的。如果按照我之前的代码来运行的话,会在tableCellAtIndex函数中崩溃,这是为什么呢?因为我们在创建tableview的时候,给每个tableview设置tag并没有成功,那为什么没成功呢?因为我们还没设置好tag的时候,tableCellAtIndex这斯就跑起来了,我们通过table->getTag(),其实是取不到tag的,既然取不到,那么之后就不能创建图片文字,会调用空指针,所以程序就BOOM了。那么罪魁祸首就是TableView::create(this,ViewSize);这个家伙了,我们调试跟踪进源码,如下:

倒数第二句table->_updateContentSize();里面会调用tableCellAtIndex这个函数。那么找到问题了该怎么解决呢,难懂要改源码?不用,我们可以这样创建tableview,如下:

那么为什么不把table->_updateCellPositions();也搞进来,因为这是保护成员函数,所以不能访问,而且也用不上,以后遇到类&#;的问题也可以这样解决。然后把三个tableview改过来就ok啦。

代码及资源下载处:

Cocos2dx CCLabelAtlas字体与CCLabelTTF字体的使用方法 1.、字体1、CCLabelAtlas字体示例代码:CCLabelAtlas*LBsocre4=CCLabelAtlas::create(CCString::createWithFormat(%d,c)-getCString(),labelatlasimg.png,,,'0');LBsocre4-setAnchorPoint(ccp(0,0.

Bullet(Cocos2dx)之创建地形 Bullet提供了几个类btBvhTriangleMeshShape,btHeightfieldTerrainShape去创建一些网图形,首先了解btHeightfieldTerrainShape,通过高度图数据创建一个3D地形。Astaticmeshthat

Cocos2dx ParticleEditor粒子编辑器 下载地址:程序调用代码:(plist文件要和贴图在同一目录)//创建粒子对象CCParticleSystem*lizi=newCCParticleSystemQuad();//设置plist动画文件lizi-initWithFile(rain1.pli

标签: cocos2d-js-min.js

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

上一篇:cocos2dx3.2开发 RPG《Flighting》(二)骨骼动画介绍及游戏美术资源分享(cocos开发游戏)

下一篇:Cocos2dx CCLabelAtlas字体与CCLabelTTF字体的使用方法

  • 认证不过的进项税是怎么调出分录?
  • 跨年的所得税会计分录
  • 税务问答网站
  • 企业缴纳季度所得税
  • 收到天使投资如何做账
  • 营改增之后对企业的影响
  • 非居民企业出租境内不动产
  • 哪些类型的合同无效
  • 专用凭证和通用凭证的联系和区别
  • 进项税额抵扣一般多少
  • 事业单位发生管理费用
  • 关于转让费的问题
  • 房屋租赁发票需要备注吗
  • 收到政府补助怎么发朋友圈
  • 2017年一般纳税人增值税优惠
  • 税控盘离线时限为0
  • 发票上不小心印上作废两个字怎么办
  • 用于在建工程的固定资产是否可以计提折旧
  • 甲供材料如何纳税
  • 业务招待费如何进行纳税调整
  • 受托加工物资的账务处理例题
  • 研发费用计入什么科目符合资本化
  • 建筑业总产值的统计执法检查内容
  • 公司装修费用如何入账
  • linux中的文件
  • js控件的监听事件怎么使用
  • php中??
  • system 进程
  • 工程结算
  • 艾叶泡脚的功效与作用及禁忌
  • 试运行取得的收入如何进行财税处理
  • 审核过程中发现的问题应由被审核部门实施纠正
  • 愚人二部曲
  • vue3性能对比
  • 消费赠送积分
  • 办公用品开发票有哪些
  • laravel引入css
  • php读取json数组中指定内容
  • php字符
  • php如何制作登录页面
  • 前端解决跨域问题的8种方案(最新最全)
  • 业务招待费属于现金流量表中的哪个项目
  • 网络课平台用交税吗
  • 权益类证券投资包括
  • 为什么很多公司选择股票上市
  • css入门经典
  • 帝国cms灵动标签调用标题图片
  • 企业所得税的成本怎么填?
  • SQL SERVER 2008 R2 重建索引的方法
  • sql2008附加数据库错误3456
  • 代开专票上的税额比电子缴款凭证上的税额少怎么调整?
  • 累计折旧贷方余额怎么算
  • 超市预付卡销售会计分录
  • 应交税费附加税明细科目
  • 长期借款利息是财务费用吗
  • 水电费进项税额转出20%
  • 产品成本计算的分批法适用于
  • 不征税发票和零税率发票
  • 政府补贴递延收益的摊销时间
  • 暂估入库后发票来不了会计分录
  • 行政事业单位固定资产计提折旧
  • mysql如何优化sql查询
  • sql语句分号
  • 微软6月24发布
  • windows Server 2003设置磁盘配额操作图解
  • win10系统无法开机怎么修复
  • centos5.5加固
  • win8怎么调亮度调节
  • win1021h2版本千万别更新
  • jquery 多选
  • 批处理/l
  • js网页自动化
  • Android UI之LinearLayout(线性布局)
  • JavaScript开发技巧
  • jquery示例
  • koa和express的区别
  • 公租房要钱吗
  • 企业注册的步骤
  • 怎么查询地税信息表
  • 2021房屋退税流程怎么操作
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设