cocosCreator ScrollView 纵向滚动列表无限循环刷新

2024-04-28 18:18

本文主要是介绍cocosCreator ScrollView 纵向滚动列表无限循环刷新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

纵向滚动列表无限刷新,横向的稍微修改即可。原理相同。

cc.Class({extends: cc.Component,properties: {itemPref:{type: cc.Prefab,default: null,},mask:{type: cc.Node,default: null,},},// onLoad () {},//只支持纵向。
//只支持纵向。
//只支持纵向。start () {this.itemH = 100; //包括间隙this.itemTotalNum = 8;this.visibleSize = this.mask.getContentSize();this.realItemNum = Math.floor(this.visibleSize.height / this.itemH) + 2;this.itemArr = [];//测试数据this.data = []; for(var i=0; i<17; i++){this.data.push("" + i) ;}this.initItem();},initItem(){var eventHandler = new cc.Component.EventHandler();eventHandler.target = this.node;eventHandler.component = "ScrollHelper";eventHandler.handler = "onScroll";this.scroll_com  = this.getComponent(cc.ScrollView); this.scroll_com.scrollEvents.push((eventHandler)); var totalH = this.itemTotalNum*this.itemH;this.mask.getContentSize()this.scroll_com.content.setContentSize(this.visibleSize.width, totalH);this.initObj();    },initObj(){for(var i=0; i < this.realItemNum; i++){var item = cc.instantiate(this.itemPref);this.scroll_com.content.addChild(item);item.y = -this.itemH/2 - this.itemH*i;this.itemArr.push(item);this.refreshData(i, item)}},onScroll(){this.refresh();},refresh(){this.currOffset = this.scroll_com.getScrollOffset();var start_index = Math.floor(this.currOffset.y / this.itemH);  var isOutMax = this.visibleSize.height + this.currOffset.y > (this.itemTotalNum-1)*this.itemHif (start_index<0 || isOutMax){return;}for(var i=0; i < this.realItemNum; i++){var item = this.itemArr[i];var new_y = -this.itemH/2 - this.itemH*(i + start_index);item.y = new_y; this.refreshData(i + start_index, item) }},//测试数据refreshData(dataIndex, item){var lbl = item.getChildByName("lbl").getComponent(cc.Label);lbl.string = "aa"+dataIndex;}// update (dt) {},
});

 

这篇关于cocosCreator ScrollView 纵向滚动列表无限循环刷新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/943925

相关文章

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

html 滚动条滚动过快会留下边框线的解决方案

《html滚动条滚动过快会留下边框线的解决方案》:本文主要介绍了html滚动条滚动过快会留下边框线的解决方案,解决方法很简单,详细内容请阅读本文,希望能对你有所帮助... 滚动条滚动过快时,会留下边框线但其实大部分时候是这样的,没有多出边框线的滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行

SpringCloud使用Nacos 配置中心实现配置自动刷新功能使用

《SpringCloud使用Nacos配置中心实现配置自动刷新功能使用》SpringCloud项目中使用Nacos作为配置中心可以方便开发及运维人员随时查看配置信息,及配置共享,并且Nacos支持配... 目录前言一、Nacos中集中配置方式?二、使用步骤1.使用$Value 注解2.使用@Configur

Python中合并列表(list)的六种方法小结

《Python中合并列表(list)的六种方法小结》本文主要介绍了Python中合并列表(list)的六种方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、直接用 + 合并列表二、用 extend() js方法三、用 zip() 函数交叉合并四、用

Spring Boot中的YML配置列表及应用小结

《SpringBoot中的YML配置列表及应用小结》在SpringBoot中使用YAML进行列表的配置不仅简洁明了,还能提高代码的可读性和可维护性,:本文主要介绍SpringBoot中的YML配... 目录YAML列表的基础语法在Spring Boot中的应用从YAML读取列表列表中的复杂对象其他注意事项总

uniapp小程序中实现无缝衔接滚动效果代码示例

《uniapp小程序中实现无缝衔接滚动效果代码示例》:本文主要介绍uniapp小程序中实现无缝衔接滚动效果的相关资料,该方法可以实现滚动内容中字的不同的颜色更改,并且可以根据需要进行艺术化更改和自... 组件滚动通知只能实现简单的滚动效果,不能实现滚动内容中的字进行不同颜色的更改,下面实现一个无缝衔接的滚动

C++类和对象之初始化列表的使用方式

《C++类和对象之初始化列表的使用方式》:本文主要介绍C++类和对象之初始化列表的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C++初始化列表详解:性能优化与正确实践什么是初始化列表?初始化列表的三大核心作用1. 性能优化:避免不必要的赋值操作2. 强

Nginx部署React项目时重定向循环问题的解决方案

《Nginx部署React项目时重定向循环问题的解决方案》Nginx在处理React项目请求时出现重定向循环,通常是由于`try_files`配置错误或`root`路径配置不当导致的,本文给大家详细介... 目录问题原因1. try_files 配置错误2. root 路径错误解决方法1. 检查 try_f

Spring三级缓存解决循环依赖的解析过程

《Spring三级缓存解决循环依赖的解析过程》:本文主要介绍Spring三级缓存解决循环依赖的解析过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、循环依赖场景二、三级缓存定义三、解决流程(以ServiceA和ServiceB为例)四、关键机制详解五、设计约

Spring 中的循环引用问题解决方法

《Spring中的循环引用问题解决方法》:本文主要介绍Spring中的循环引用问题解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录什么是循环引用?循环依赖三级缓存解决循环依赖二级缓存三级缓存本章来聊聊Spring 中的循环引用问题该如何解决。这里聊