Cocos Creator3.8 项目实战(六)Combobox控件的实现和使用

2023-10-07 02:45

本文主要是介绍Cocos Creator3.8 项目实战(六)Combobox控件的实现和使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


在cocoscreator 中,没有Combobox控件,无奈之下只能自己动手写一个。


⚠️ 文末附 ComboBox.ts 、ComboBoxItem.ts 完整源码, 可直接拿去使用。


实现原理:

1、Combobox 背景图background 是一个sprite 控件,上面放了一个label 控件,用于显示选择后的文本。

2、点击 background 背景图显示 下拉列表dropDown,同时变更右边的小三角方向,向下。

3、下拉列表dropDown采用scrollow实现,点击列表项后,隐藏 dropDown ,更新 label 控件显示文本,变更右边的小三角方向,向左。


实现效果

在这里插入图片描述


下面详细介绍使用方法:

step 1 ,在creator层级管理器中,新建 combobox 节点,并做如下配置:

在这里插入图片描述


combobox: 是一个空node 节点,作为根节点

background:背景图,是一个sprite 控件,响应点击事件

Label:combobox 选择后的文本显示

Triangle_button_flg:小三角

dropDown: scrollow 控件

content 添加 vLayout 垂直方向布局


在这里插入图片描述


step 2 ,独立新建一个 预制体文件 comboboxitem. prefab ,并在层级管理器中做以下布局配置:

Bg: 背景用于响应事件

label :显示文本项

在这里插入图片描述


在这里插入图片描述


step 3 ,在层级管理器中选择 combobox 节点, 在属性检查器中,将ComboBox.ts 脚本挂载到combobox 节点下。

并配置对应的属性,如下图:

在这里插入图片描述


step 4 ,在层级管理器中选择 comboboxitem 节点, 在属性检查器中,将ComboBoxItem.ts 脚本挂载到comboboxitem 节点下。

并配置对应的属性,如下图:

在这里插入图片描述


step 5、 ComboBox.ts 完整源码

import { _decorator, Component, Node,Label,instantiate, UITransform,Tween, Prefab, Sprite } from 'cc';
const { ccclass, property } = _decorator;
import {ComboBoxItem} from "./ComboBoxItem"@ccclass('ComboBox')
export class ComboBox extends Component {@property(Sprite)background:Sprite;/*** 下拉按钮右边的小三角形*/@property(Node)triangle:Node;/*** 下拉按钮上显示的文本*/@property(Label)comboLabel:Label;/*** 下拉框*/@property(Node)dropDown:Node;/*** 垂直布局*/@property(Node)vLayoutNode:Node;/***  滚动视图内容*/@property(Node)contentNode:Node;/***  下拉框选项*/@property(Prefab)itemPrefab:Prefab;/***  是否下拉状态*/isDropDown:boolean = false;/***  下拉框选项内容*/itemArray:Array<string>=[];onLoad() {this.init();}setData(itemArray:Array<string>){this.itemArray.splice(0,this.itemArray.length);this.itemArray =itemArray;this.resetView();}initData(){//  let itemArray = ['Cocos Creator', 'Cocos-2dx', 'Cocos2d-js', 'Cocos2d-Lua', 'Cocos Creator 3D', 'Cocos Service', 'Cocos社区'];//  this.setData(itemArray);}resetView(){let totalHeight = 0;for (let i=0; i<this.itemArray.length; i++) {let item = instantiate(this.itemPrefab);let comboBoxItem:ComboBoxItem = item.getComponent(ComboBoxItem).init(this);comboBoxItem.content.string = this.itemArray[i];this.vLayoutNode.addChild(item);totalHeight += item.getComponent(UITransform).height;}// 设置content高度if (totalHeight > this.contentNode.getComponent(UITransform).height){this.contentNode.getComponent(UITransform).height = totalHeight;}}// 子项点击后改变下拉按钮上的文本// 更新选择后小三角和下拉框显示updateComboboxLabel(selText:string) {this.comboLabel.string = selText;this.isDropDown = false;this.dropDown.active = this.isDropDown;this.rotateTriangle();}//获取当前选择的文本getComboboxLabel():string {return this.comboLabel.string;}init() {this.isDropDown = false;this.dropDown.active = false;this.background.node.on(Node.EventType.TOUCH_START, this.onClicked, this);}onClicked(event:Event) {this.isDropDown = true;this.dropDown.active = this.isDropDown;this.rotateTriangle();}//旋转小三角rotateTriangle () {// step1: 创建一个针对目标的Tween对象// 旋转小三角形(正值为逆时针,负值为顺时针)let tw = new Tween(this.triangle);if (!this.isDropDown) {// step2: 添加执行过程tw.to(0.5, {angle:-90});}else {// step2: 添加执行过程tw.to(0.5, {angle:0});}// step3: 开始执行tween对象tw.start();}start() {this.initData()}update(deltaTime: number) {}
}

step 6、 ComboBoxItem.ts 完整源码

import { _decorator, Component, Node,Label } from 'cc';
const { ccclass, property } = _decorator;@ccclass('ComboBoxItem')
export class ComboBoxItem extends Component {@property(Node)bg:Node;@property(Label)content:Label;comboBox:any;start() {}update(deltaTime: number) {}init(comboBox:any):ComboBoxItem{this.comboBox = comboBox;this.bg.on(Node.EventType.TOUCH_START, this.onClicked, this);return this;}onClicked(event:Event) {this.comboBox.updateComboboxLabel(this.content.string);}}

这篇关于Cocos Creator3.8 项目实战(六)Combobox控件的实现和使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u