• 【Cocos新手进阶】通过cocos实现可控制的动态加载更新的日志界面效果


    本篇文章主要讲解,通过cocos实现可控制的动态加载更新的日志界面效果。
    日期:2023年11月15日
    作者:任聪聪

    效果演示:

    效果说明:在一个界面可以动态输出for循环的结果并更新到界面中进行不断加载的日志页面效果,可用做loading加载和相关动态操作的显示情景中。
    在这里插入图片描述

    实现步骤:

    步骤一、打开我们的cocos creator 如下图:

    在这里插入图片描述

    步骤二、配置我们的相关界面组件,如下图所示层级及名称关系:

    在这里插入图片描述
    注意:背景和相关的实例配置信息在文章所关联的附件中,如果是新手不知道如何配置界面,可以直接拿实例导入运行。

    步骤三、创建home.ts脚本及相关预制体信息,如下:

    在这里插入图片描述

    步骤四、填充home.ts脚本,并关联home场景

    home.ts脚本

    const {ccclass, property} = cc._decorator;
    import item from "./item";
    @ccclass
    export default class NewClass extends cc.Component {
    
        @property(cc.Node)
        scrollViewObj: cc.Node = null;   
    
        @property(cc.Node)
        itemPrefabFather: cc.Node = null;   
    
        @property(cc.Prefab)
        itemPrefab: cc.Prefab = null;
    
        @property(cc.Button)
        button: cc.Button = null;
    
        @property(cc.Label)
        text: cc.Label = null;
    
        @property(cc.Label)
        button_text: cc.Label = null;
    
        private logsData:any = [];
        private idx:number = 0;
        private startLogs:boolean  = false;
        // LIFE-CYCLE CALLBACKS:
    
        onLoad () {
            let that = this;
            that.logsData = [];
            for(var i = 0;i<1000;i++){
                let newLogsData = {'string':'正在执行日志信息id'+i+"的进度加载~"}
                that.logsData.push(newLogsData);
            }
        }
    
        startBtn(){
            let that = this;
            that.startLogs = that.startLogs?false:true;
            that.text.string = that.startLogs?"正在加载中....":"已停止";
            that.button_text.string = that.startLogs?"停止":"继续";
        }
    
        start () {
            let that = this;
            cc.log('加载日志数据:',that.logsData)
        }
    
        update (dt) {
            let that = this;
            console.log(dt);
            if(that.idx<1000&&that.startLogs){
                that.idx++;
                let logItem = that.logsData[that.idx]
                let prefabItem = cc.instantiate(that.itemPrefab);
                prefabItem.parent = that.itemPrefabFather;
                prefabItem.getComponent(item).initThisPrefab(logItem);
                // 获取ScrollView组件
                const scrollView = that.scrollViewObj.getComponent(cc.ScrollView);
                // 将ScrollView的垂直滚动位置设置为底部
                scrollView.scrollToBottom(0);
            }
        }
    
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67

    点击添加用户组件关联脚本信息

    说明:并将所有的组件信息进行关联。
    在这里插入图片描述

    步骤五、填充预制体 item.ts脚本及关联脚本信息

    item.ts

    const {ccclass, property} = cc._decorator;
    
    @ccclass
    export default class NewClass extends cc.Component {
    
        @property(cc.Label)
        label: cc.Label = null;
    
        // LIFE-CYCLE CALLBACKS:
    
        // onLoad () {}
    
        initThisPrefab (data:any) {
            let that = this;
            that.label.string = data.string;
        }
    
        // update (dt) {}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    关联预制体

    说明:创建预制体则是将场景中的普通节点拖拽到底部的asset中,如果不清楚如何制作预制体可以看我以往栏目下的预制体制作的相关文章。
    在这里插入图片描述

    步骤六、保存场景及预制体的信息,并点击运行按钮

    在这里插入图片描述
    end:大功告成!

  • 相关阅读:
    一文读懂区块链互操作性 - web3.0-区块链-元宇宙
    【SpringBoot】详细介绍SpringBoot中Entity类中的getters和setters
    JAVA G1垃圾收集器介绍
    【开源项目】libfaketime安装、使用——小白教程
    ERP项目施行计划的目的是什么?
    lambda nodejs 函数降低冷启动时间的最佳实践
    简单但好用:4种Selenium截图方法了解一下!
    quarkus实战之一:准备工作
    内网离线安装Nginx并配置SSL
    二、IAR新建一个工程
  • 原文地址:https://blog.csdn.net/hj960511/article/details/134421738