位置: 编程技术 - 正文

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字体的使用方法

  • 办税员的工作职责
  • 进项税额转出怎么结平
  • 几年前的发票能入账吗
  • 外管证过期了一个月罚款多少
  • 计税金额是含税还是不含税
  • 税务机关六位地区编码是什么
  • 发票隔月报送可以么?
  • 破坏公司财产员工怎么处理
  • 收到违约金需要缴纳所得税吗
  • 废旧物资回收需要什么手续
  • 收到政府补助怎么发朋友圈
  • 报废车辆补贴收据怎么写
  • 房屋使用权转让合法吗
  • 记账凭证的分类和基本内容
  • 员工收到货款不交公司,法律规定
  • 社保打的生育保险怎么做账
  • 如何把操作系统转移到固态硬盘
  • win10更新windows
  • iphone微信透明壁纸怎么设置
  • 盈亏余额
  • 收到对方给的发票怎么做账
  • 安装费如何做账
  • php实现基数排序函数
  • 冲减预付款
  • 购买增值税防伪税控系统专用设备
  • 补缴的耕地占用税怎么做账
  • 抵扣农产品进项税时,也要抵扣运费吗
  • PHP:spl_autoload_unregister()的用法_spl函数
  • 企业清算剩余财产分配是否交个人所得税
  • Linux系统中怎么定位到java代码的方法级
  • 长期股权投资引入新投资者账务处理
  • 商品盘点短缺和溢余的核算
  • 怎么处理坏账准备的问题
  • node升级版本
  • 出售报废边角料税率
  • 实收资本本年利润属于什么科目
  • php实现原理
  • 关于php通用返回的问题
  • php遍历数组使用的是foreach
  • vue优化方案
  • 勘察设计四个阶段
  • 原始凭证必须来源于外部吗
  • css基础实验报告
  • ai训练流程
  • 帝国cms配置数据库
  • 托收的收款人是谁
  • 增值税进项税如何申报
  • 报个税收入需要减去扣款金额吗
  • 购进固定资产的进项税可以抵扣吗
  • java初学者教程
  • 公司认缴出资怎么交税
  • 固定资产的主要风险和关键控制点有哪些?
  • 什么样的公司可以申请破产
  • 印花税购销合同改为买卖合同
  • 公司性质不一样的重名可以吗
  • 申请电子发票需要什么条件
  • 研发费用加计扣除新税收政策2023
  • 商场收租户电费会计分录
  • 公司两年未给员工申报个税违法吗
  • 核定征收需要什么资料
  • 商品流通企业有哪些企业
  • ubuntu的系统设置在哪里
  • 同一个局域网中,可以有两台dhcp服务器吗?为什么?
  • sesvc.exe是什么
  • win1020h2无法重启
  • Win10预览版更新弹窗如何关闭
  • win7右下角无线网络连接图标不见了
  • js 原型链继承 原型式继承
  • python中myf
  • linux shell -s
  • html页面头部
  • unity ulua
  • javascript用处
  • python解析excel文档
  • comparable接口怎么用
  • python 管理系统
  • 税务稽查追溯时间是什么意思
  • 北京国家税务网官网首页
  • 武汉市国税局长
  • 一级稽查体制
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设