位置: 编程技术 - 正文

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

  • 无形资产摊销的会计科目
  • 无票收入在增值税表中填哪
  • 公司买手表账务处理
  • 房租收入怎么报税
  • 第二季度是多少钱
  • 律师费的发票税率怎么算
  • 银行手续费发票图片
  • 虚开增值税立案标准
  • 委托外单位加工发出的材料分录
  • 供货商对账单跨月返利怎么做账?
  • 跨年度借款利息的税务处理怎么做?
  • 机器设备的损耗属于什么会计科目类别
  • 工程施工企业人工成本最高多少
  • 营改增后小规模纳税人所得税
  • 分摊的水费应取得何种扣除凭证
  • 离职补偿怎么做工资
  • 公司开一般户弊端
  • 税金当月计提当月缴纳
  • 对方已认证的发票在哪里
  • 公司开业厂商的宣传文案
  • php各大框架以及实现原理
  • 农村自建房买卖怎样才合法
  • 企业事业单位应当采取有效措施
  • php数据库语句
  • 设备租赁费属于劳务吗
  • 2021发票勾选认证
  • 发票抵税是怎么申报的
  • 美国布莱斯大峡谷成因
  • 增值税留抵退税怎么操作
  • 以前年度损益调整账务处理分录
  • 销售货物产生的运费怎么开票
  • yolov5m
  • 自学前端,你必做的事
  • 常用的css样式有哪些
  • web 前端
  • 企业所得税的调增调减怎么理解
  • 工会经费计算公式的例子
  • 预算会计年末怎么结账
  • 现金流量表要填满吗
  • 网上申报完还需要去税务局吗
  • 计提税费可以记入成本吗
  • 给客户的现金奖励会计处理
  • 工程发票多少点
  • 企业固定资产纳税
  • 税款减免怎么做分录
  • 结账与对账的共同意义在于
  • 捐赠纳税调整额怎么算
  • 复利现值系数表怎么算
  • 公司盈利的钱怎么拿出来
  • 营业外收入主要来源
  • 绿色安装包怎么卸载
  • mssql in
  • ntfs win98
  • 盗版win8 1升级win10
  • win2003和xp一样吗
  • 让windows10蓝屏
  • ubuntu20.4分区
  • exe什么意思?
  • crossfire.exe是什么
  • zmweb.exe是什么进程
  • 查找linux
  • 新买的笔记本电脑需要做什么
  • win8怎么把网速调到最快
  • win10搭建ftp服务器的步骤
  • uisrollview
  • js实现图片放大功能
  • 用python编写登录程序
  • nodejs yield
  • python函数菜鸟教程
  • python 获取网页上文件地址
  • js 页面加载
  • js class实现原理
  • android监听app启动
  • 浅谈建筑地基基础加固施工技术亲
  • python安装基础教程
  • javascript教程 csdn
  • js点击按钮实现登陆网页
  • 广西空置房物业费减免政策吗
  • 工商变更与税务变更为什么不能同步
  • 国税年收入
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设