【Cocos新手进阶】父级预制体中的数据列表,在子预制体中的控制方法!

本篇文章主要讲解,cocos中在预制体操作过程中,父级预制体生成的数据列表中,绑定了子预制体中的事件,在子预制体的时间中如何控制上级列表的具体操作教程。
日期:2023年11月10日
作者:任聪聪

一、实际效果情况

在这里插入图片描述

说明:预制体弹出框中的预制体item,给予item预制体的文本绑定点击事件,点击后即可传递数据到父级home脚本中进行更新。

二、制作父级预制体及子预制体

步骤一、创建空节点,如下图

在这里插入图片描述

步骤二、创建名为“popup_list” 的节点及背景图如下图。

在这里插入图片描述
注意:点击修改所有的信息如图红框内所示。

步骤三、创建滚动窗

在这里插入图片描述
创建后,名称改为ScrollView:
在这里插入图片描述

步骤四、将item设置为预制体

注意:记得解锁左侧的红色小锁,点击一下就可以。
在这里插入图片描述
设置完毕:
在这里插入图片描述
创建对应的预制体脚本,如下图,item.ts:
在这里插入图片描述

步骤五、创建home场景,及home脚本并将上述的弹出界面存到里面

在这里插入图片描述
说明:点击保存即可进行配置,优先创建空的home,然后保存到home的fire界面。

创建home脚本,并声明预制体及父节点信息,如下内容:
home.ts

import item from "./prefab/item";

const {ccclass, property} = cc._decorator;

@ccclass
export default class home extends cc.Component {

    @property({
        type: cc.Node,
        displayName: "预制体父节点"
    })
    protected prefabFatherNode: cc.Node = null;

    @property({
        type: cc.Prefab,
        displayName: "item预制体"
    })
    protected itemPrefab: cc.Prefab = null;
 
    protected preData: Array<{ title: string,id:number,bg_color:string}> = [];
 
    onLoad() {
        this.node.on('up_list', this.onListUpdate, this);
        this.echoList();
    }
    
    //监听更新
    protected onListUpdate(data: any): void {
        console.log('父节点回收到的数据:', data.detail);
        this.echoList(data.detail.id);
    }

    //输出列表
    echoList(theId=0){
        let that = this;
        let temporaryData = null;
        let num = 0;
        for (let i = 0; i < 60; i++) {
            temporaryData = {
                title: "",
                id: 0,
                bg_color: "#000000",
            };
            const id = ++num;
            temporaryData.title = `${id}`;
            temporaryData.id = id;
            that.preData.push(temporaryData);
        }
        console.log(that.preData);
        if (theId !== 0) {
            // 更新预制体
            let prefabChildren = that.prefabFatherNode.children;
            for (let i = 0; i < prefabChildren.length; i++) {
                let prefabChild = prefabChildren[i];
                let itemComponent = prefabChild.getComponent(item);
                //that.preData 会记录上一次的修改,所以要进行颜色的还原
                that.preData[i].bg_color = "#000000";
                if (itemComponent && itemComponent.getData().id === theId) {
                    that.preData[i].bg_color = "#C0331F";
                }
                itemComponent.updatePre(that.preData[i]);
            }
        } else {
            // 创建新的预制体
            let length = that.preData.length;
            for (let i = 0; i < length; i++) {
                let prefabricatedObject = cc.instantiate(that.itemPrefab);
                prefabricatedObject.parent = that.prefabFatherNode;
                prefabricatedObject.getComponent(item).createdPre(that.preData[i]);
            }
        }
    }
    // update (dt) {}
}

配置content属性:

在这里插入图片描述
给home.ts绑定脚本:
在这里插入图片描述
拖拽关联预制体和父节点:
在这里插入图片描述

步骤六、创建预制体并绑定脚本

点击打开预制体:
在这里插入图片描述
点选预制体场景信息后,在左侧进行用户脚本的关联如下图:
在这里插入图片描述
说明:选择item。

配置item.ts的脚本内容:

const {ccclass, property} = cc._decorator;

@ccclass
export default class item extends cc.Component {

    @property(cc.Label)
    label: cc.Label = null;

    private data: any = null; // 保存预制体的数据

    //点击事件监听 回调到home脚本
    protected onClick(theId): void {
        console.log("点击测试");
        let newData = {'id':theId}; 
        let customEvent = new cc.Event.EventCustom('up_list', true);
        customEvent.detail = newData;//自定义的数据调用处
        this.node.dispatchEvent(customEvent);//亲测有效的方式,使用this.node.parent.emit("xxxx",{[]});没有反应
    }

    /**
     * 初始化
     * @param data 
     */
    createdPre(data: { title: string,id:number,bg_color:string }) {
        let that = this;
        that.data =data;
        console.log(data);
        that.label.string = "我是第:"+data.title+"个,预制体。";
        that.label.node.color = new cc.Color().fromHEX(data.bg_color);
        //给label 注册事件监听
        that.node.on(cc.Node.EventType.TOUCH_END,function(){
            const theId = data.id;//获取当前的id并返回,用于更新数据
            that.onClick(theId);
        })
    }

    //更新预制体
    updatePre(data: any) {
        this.data = data;
        this.label.string =  "我是第:"+data.title+"个,预制体。";
        this.label.node.color = new cc.Color().fromHEX(data.bg_color);
    }

    //返回当前预制体的数据
    getData(): any {
        return this.data;
    }

}

关联对象信息,拖拽到指定的框即可:
在这里插入图片描述
end:大功告成,运行进行测试。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/127846.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS NEXT 调优工具 Smart Perf Host 高效使用指南

在软件开发的过程中&#xff0c;很多开发者都经常会遇到一些性能问题&#xff0c;比如应用启动慢、点击滑动卡顿、应用后台被杀等&#xff0c;想要解决这些问题势必需要收集大量系统数据。而在收集数据的过程中&#xff0c;开发者则需要在各种工具和命令之间来回切换&#xff0…

LV.12 D17 中断控制器 学习笔记

一、中断控制器 在处理IRQ的时候&#xff0c;会将CPSR写入IRQ_SPSR&#xff0c;然后将CPU切换为IRQ模式&#xff0c;把状态改成ARM状态&#xff0c;把I位写成1禁止全部的IRQ&#xff0c;所以中断这样是我们不想要的。4412是一个四核的CPU&#xff0c;在发送中断前要确定发送给哪…

灵活调整宣传策略,媒体发稿和新闻发布的优势所在

企业在当今信息爆炸的时代&#xff0c;要想在市场竞争中脱颖而出&#xff0c;提高公信力是至关重要的。而媒体发稿和新闻发布是提升企业公信力的重要手段之一。下面将从门户网站的权威展示、搜索引擎排名的提升、内容的持续稳定有效性、内容的可改性以及协助增加网站流量等方面…

零基础入门Python基础知识全面梳理!从零开始成为编程高手

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、python程序的组成二、核心的数字类型1.整型 int &#xff08;0、负自然数、正自然数&#xff09;2.浮点数 float &#xff08;带有小数部分的数&#xff0c;小数…

【nginx】使用arthas协助定位 nginx 499

看到这个499 到服务端 通过arthas查看 并没有耗时很长的 心跳接口 看都是很快的 通过 monitor 命令 通过watch 定位看到这个现象&#xff1a; watch -x 3 在nginx配置文件中添加 在nginx 中查看 没有499 了 再看nginx 中有存在 401 这个是业务问题 剩下的是检测器同事定位…

再服务器上配置其他版本的DGL

1、先创建pytorch环境&#xff1a;conda create -n ljj_torch190 python3.8 conda activate ljj_torch190 2、下载pytorch&#xff08;带上了cuda111&#xff09; Start Locally | PyTorch 这里面没有安装CUDA Toolkit&#xff0c; 所以需要再安装匹配cuda的toolkits&#xf…

React【axios、全局处理、 antd UI库、更改主题、使用css module的情况下修改第三方库的样式、支持sass less】(十三)

文件目录 Proxying in Development http-proxy-middleware fetch_get fetch 是否成功 axios 全局处理 antd UI库 更改主题 使用css module的情况下修改第三方库的样式 支持sass & less Proxying in Development 在开发模式下&#xff0c;如果客户端所在服务器跟后…

解决Web server failed to start. Port XXXX was already in use.

这句错误描述意思是&#xff1a;当前程序的端口号被占用了&#xff0c;需要将占用该端口的程序停止掉才行。 解决方案&#xff1a; 1.winR键调出运行窗口&#xff0c;输入cmd进入命令行: 2.输入命令netstat -ano|findstr "XXXX"查看“XXXX”对应端口的程序占用情况…

winui3开发笔记(二)自定义标题栏

参考文章链接&#xff1a;https://www.programminghunter.com/article/46392310600/ 注意事项 获取 AppWindowTitleBar 的实例并设置其颜色属性时&#xff0c;InitializeTitleBar(AppWindow.TitleBar);&#xff0c;只适用于Windows App SDK 1.2及以上&#xff0c;所以如果用w…

Linux文件系统

文章目录 引言磁盘文件系统每个分组(一个block group)中存的都是什么目录文件 软链接&#xff1a;软链接应用场景 硬链接硬链接应用场景硬链接和软链接的区别 引言 在此之前我们谈论重定向等问题都是指被打开的文件&#xff0c;现在我们来学习一下未被打开的文件&#xff0c;以…

【Proteus仿真】【51单片机】水质监测报警系统设计

文章目录 一、功能简介二、软件设计三、实验现象联系作者 一、功能简介 本项目使用Proteus8仿真51单片机控制器&#xff0c;使用按键、LED、蜂鸣器、LCD1602、PCF8591 ADC、PH传感器、浑浊度传感器、DS18B20温度传感器、继电器模块等。 主要功能&#xff1a; 系统运行后&…

【GUI软件开发】小红书评论采集:自动采集1w多条,含二级评论!

文章目录 一、爬取目标1.1 效果截图1.2 演示视频1.3 软件说明 二、代码讲解2.1 爬虫采集模块2.2 软件界面模块2.3 日志模块 三、附完整源码及软件 一、爬取目标 您好&#xff01;我是马哥python说 &#xff0c;一名10年程序猿。 我用python开发了一个爬虫采集软件&#xff0c…

矩阵起源荣获第八届“创客中国”深圳市中小企业创新创业大赛三等奖

近日&#xff0c;2023年第八届“创客中国”深圳市中小企业创新创业大赛圆满落下帷幕&#xff0c;矩阵起源&#xff08;深圳&#xff09;信息科技有限公司凭借项目”MatrixOne 新一代超融合异构云原生数据库”荣获企业组三等奖。 本届大赛由深圳市工业和信息化局、深圳市中小企业…

如何用Python3+requests+unittest实现接口自动化测试实战

一、Requests介绍 首先让我们来看 Requests 官方的介绍&#xff1a; Requests is an elegant and simple HTTP library for Python, built for human beings. 翻译过来就是&#xff1a;Requests 是为人类写的一个优雅而简单的 Python HTTP 库。这个介绍很直白了&#xff0c;…

ElasticSearch文档分析

ElasticSearch文档分析 包含下面的过程&#xff1a; 将一块文本分成适合于倒排索引的独立的 词条将这些词条统一化为标准格式以提高它们的“可搜索性”&#xff0c;或者 recall 分析器执行上面的工作。分析器实际上是将三个功能封装到了一个包里&#xff1a; 字符过滤器 首先&a…

乐优商城(三)品牌管理

1. 品牌的新增 1.1 url 异步请求 点击品牌管理下的新增品牌&#xff0c;填写品牌信息后提交 2.打开浏览器控制台 由此可以得知&#xff1a; 请求方式&#xff1a;POST请求路径&#xff1a;/item/brand请求参数&#xff1a;{name: “测试品牌”, image: “”, cids: “76,32…

云端生成式 AI – 基于 Amazon EKS 的 Stable Diffusion 图像生成方案

Stable Diffusion 是当下生成式 AI 领域最受欢迎的开源多模态语言-图像模型&#xff0c;由于其易用的接口和良好的使用体验&#xff0c;受到了开源社区和广大设计行业从业者的追捧。Stable Diffusion 模型版本正在快速迭代&#xff0c;并带动了各行各业的生产力变革。目前市场上…

SAP 40策略测试及简介

相信很多很多的行业中都会用到40策略按库存生产,接下来我们将详细的测试40策略 1、首先准备好成品物料AB2。 2、创建BOM—cs01 3、创建主配方C202 ,如果是离散制造的话就是创建工艺路线CA01 4、创建生产版本C223 5、同样的AB2物料增加库存20KG。 6、创建计划独立需求MD…

微信智能机器人开发-基于E云管家,实现强大的个微管理

本文介绍了如何利用E云管家开发一个功能丰富的微信智能机器人。E云管家是一个开发协议&#xff0c;为微信机器人提供了强大的功能支持&#xff0c;包括关键字回复、自动通过好友和自动发朋友圈等特性。我们将通过一个简单的示例演示如何在E云管家下实现这些功能&#xff0c;并附…

EMERSON艾默生变频器维修M600/M701/M702

艾默生变频器维修常见系列&#xff1a; EV1000 系列&#xff1a;体积小&#xff0c;操作简便&#xff0c;适用于塑料机械、纺织机械、烟草机械、陶瓷机械、制药机械食品机械、印刷机械、包装机械、空调等专用设备配套。 EV2000 系列&#xff1a;功率范围广&#xff0c;功能更…