位置: 编程技术 - 正文

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

  • 交个税步骤
  • 小规模减免增值税要交企业所得税吗
  • 网银数字证书年费计入什么科目
  • 营业外收入做销项税调整
  • 劳务费属于印花税范围吗
  • 中标服务费计入什么会计科目
  • 继续教育专项扣除金额
  • 一般纳税人月销售额多少免征增值税
  • 领料投入生产会计分录
  • 房产税按原值计算公式
  • 企业税收标准是多少
  • 派发股票股利如何入账处理合适?
  • 坏账准备一般余额在哪方
  • 公司购入房产账务处理
  • 国税地税企业所得税划分
  • 私车公用税务处理办法
  • 发票打印机的字偏上
  • 小规模纳税人咨询费税率
  • 反倾销税税率查询
  • 纳税人识别号和税号是一个意思吗
  • 固定资产合并抵扣增值税
  • 汽车发票金额怎么算
  • 销售库存商品的记账凭证
  • 自行生产的存货转固定资产怎么做账
  • 属于外来凭证的单据是
  • 公司买的理财产品怎么做账
  • 上个月退货会计分录
  • 公司向股东借款合法吗
  • 王者荣耀中程咬金的克星是谁
  • 公司代缴社保公司吃亏吗
  • typecho插件开发教程
  • help是什么文件夹可以删除吗
  • rundll32.exe进程很多
  • 埃姆雷莫尔
  • 私营独资企业的税收规定
  • 酒店购买天然气流程
  • 小微企业免教育附加
  • 分公司股东怎么填
  • less命令怎么用
  • php实现支付宝支付
  • 企业对于预支工资的建议
  • 报税系统如何导出发票
  • 现金流量表的编制方法和计算公式
  • python中chr函数介绍
  • 货物搬运费会计科目
  • 小规模纳税人的企业所得税怎么算
  • 小规模纳税人应交税费科目设置
  • 如何拉企业纳税申报表
  • 政府奖励收入会计分录
  • sql server 查看
  • 核定征税是什么意思
  • 经营性现金净流量公式
  • 工业销售产值是销售收入吗
  • 交易性金融资产属于流动资产
  • 退还多余的预收款项的会计分录
  • 厂房监理要点
  • 发票信息不一致是怎么回事
  • 账外资产处理
  • 缴纳房产税和城镇房产税
  • 酒店酒水成本核算表
  • ROW_NUMBER SQL Server 2005的LIMIT功能实现(ROW_NUMBER()排序函数)
  • mssql in
  • sql中nullif
  • ubuntu20.04 u盘
  • freebsd怎么样
  • freebsd11.3安装教程
  • Win10 Mobile 10572预览版新增中文简体五笔输入法
  • 如何手动添加开机密码
  • 双系统重装win11
  • win8兼容性比win7好吗
  • win8.1升级到win10
  • popupwindow底部弹出
  • 第一个闹钟
  • Node.js中的什么模块是用于处理文件和目录的
  • jquery 图片插件
  • sdk和安卓版本
  • 包头市税务局赵文胜
  • 电子税务局讲解
  • 社保工资申报错了可以重新申请吗
  • 发票被暂停了严重吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设