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开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

Java根据IP地址实现归属地获取

《Java根据IP地址实现归属地获取》Ip2region是一个离线IP地址定位库和IP定位数据管理框架,这篇文章主要为大家详细介绍了Java如何使用Ip2region实现根据IP地址获取归属地,感兴趣... 目录一、使用Ip2region离线获取1、Ip2region简介2、导包3、下编程载xdb文件4、J

PyQt5+Python-docx实现一键生成测试报告

《PyQt5+Python-docx实现一键生成测试报告》作为一名测试工程师,你是否经历过手动填写测试报告的痛苦,本文将用Python的PyQt5和python-docx库,打造一款测试报告一键生成工... 目录引言工具功能亮点工具设计思路1. 界面设计:PyQt5实现数据输入2. 文档生成:python-

Android实现一键录屏功能(附源码)

《Android实现一键录屏功能(附源码)》在Android5.0及以上版本,系统提供了MediaProjectionAPI,允许应用在用户授权下录制屏幕内容并输出到视频文件,所以本文将基于此实现一个... 目录一、项目介绍二、相关技术与原理三、系统权限与用户授权四、项目架构与流程五、环境配置与依赖六、完整

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

浅析如何使用xstream实现javaBean与xml互转

《浅析如何使用xstream实现javaBean与xml互转》XStream是一个用于将Java对象与XML之间进行转换的库,它非常简单易用,下面将详细介绍如何使用XStream实现JavaBean与... 目录1. 引入依赖2. 定义 JavaBean3. JavaBean 转 XML4. XML 转 J

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel