cocos creator让所有button点击时播放音效

原理:

利用prototype属性,通过重写 cc.Button.prototype._onTouchEnded 方法,以便在按钮被点击时播放音频。通过重写其 _onTouchEnded 方法,可以添加自定义行为,如播放音频。

概念解释:

prototype:每个 JavaScript 函数都有一个 prototype 属性,这个属性是一个对象。这个对象包含了所有实例对象共享的属性和方法。JavaScript 对象通过原型链实现继承。当你访问一个对象的属性或方法时,JavaScript 引擎会首先在对象自身上查找。如果找不到,它会沿着原型链(prototype)向上查找,直到找到该属性或方法,或者到达原型链的顶端(即 null)。

onTouchEnded:onTouchEnded 是 cc.Button 类的一个私有方法,它处理按钮的触摸结束事件。

以下是详细的实现步骤和代码示例:

实现步骤

  1. 保存原始方法:保存 cc.Button.prototype._onTouchEnded 方法,以便在重写方法中调用原始行为。而不影响默认的方法。
  2. 重写方法:重写 cc.Button.prototype._onTouchEnded 方法,在新方法中添加播放音频的功能,然后调用原始方法。

实现代码

// 假设 AudioManager 是一个管理音频播放的单例类
class AudioManager {
    public static playButtonClickAudio() {
        // 播放按钮点击音效的逻辑
        console.log("Button click audio played");
    }
}

class CustomButton {
    public static hackCCButtonToPlayAudio() {
        // 保存原始的 _onTouchEnded 方法
        const originalOnTouchEnded = cc.Button.prototype._onTouchEnded;

        // 重写 _onTouchEnded 方法
        cc.Button.prototype._onTouchEnded = function (event) {
            // 播放按钮点击音效
            AudioManager.playButtonClickAudio();

            // 调用原始的 _onTouchEnded 方法
            originalOnTouchEnded.call(this, event);
        };
    }
}

// 在游戏初始化时调用这个方法
CustomButton.hackCCButtonToPlayAudio();

扩展功能 

有时我们并不希望所有按钮都播放同一个音效,对于有些按钮我们需要播放定制的音效,或者说我们需要根据不同的按钮标签来播放不同的音效。

这时可以在需要的按钮上添加一个自定义属性,用于指定要播放的音效文件。然后,在重写 _onTouchEnded 方法时,根据这个属性来播放对应的音效。

在 Cocos Creator 编辑器中,选中需要自定义音效的按钮节点,添加一个名为 customAudio 的属性,并设置其值为对应的音效文件名。

// 假设 AudioManager 是一个管理音频播放的单例类
class AudioManager {
    public static playAudio(audioName: string) {
        // 播放指定音效的逻辑
        console.log(`Playing audio: ${audioName}`);
        // 实际播放音效的代码,根据你的音频管理实现
    }

    public static playButtonClickAudio() {
        // 播放默认按钮点击音效的逻辑
        this.playAudio("default_button_click");
    }
}

class CustomButton {
    public static hackCCButtonToPlayAudio() {
        // 保存原始的 _onTouchEnded 方法
        const originalOnTouchEnded = cc.Button.prototype._onTouchEnded;

        // 重写 _onTouchEnded 方法
        cc.Button.prototype._onTouchEnded = function (event) {
            // 获取 customAudio 属性
            const customAudio = this.node.getComponent(cc.Button).customAudio;

            if (customAudio) {
                // 播放自定义音效
                AudioManager.playAudio(customAudio);
            } else {
                // 播放默认按钮点击音效
                AudioManager.playButtonClickAudio();
            }

            // 调用原始的 _onTouchEnded 方法
            originalOnTouchEnded.call(this, event);
        };
    }
}

// 在游戏初始化时调用这个方法
CustomButton.hackCCButtonToPlayAudio();

 根据按钮的不同标签来播放不同的音效,可以通过获取按钮的 label 属性来实现。

// 假设 AudioManager 是一个管理音频播放的单例类
class AudioManager {
    public static playAudio(audioName: string) {
        // 播放指定音效的逻辑
        console.log(`Playing audio: ${audioName}`);
        // 实际播放音效的代码,根据你的音频管理实现
    }

    public static playButtonClickAudio() {
        // 播放默认按钮点击音效的逻辑
        this.playAudio("default_button_click");
    }
}

class CustomButton {
    public static hackCCButtonToPlayAudio() {
        // 保存原始的 _onTouchEnded 方法
        const originalOnTouchEnded = cc.Button.prototype._onTouchEnded;

        // 重写 _onTouchEnded 方法
        cc.Button.prototype._onTouchEnded = function (event) {
            // 获取按钮节点上的 Label 组件
            const label = this.node.getComponentInChildren(cc.Label);

            if (label) {
                // 获取标签文本内容
                const labelText = label.string;

                // 根据标签文本内容播放不同的音效
                switch (labelText) {
                    case "Play":
                        AudioManager.playAudio("play_button_click");
                        break;
                    case "Pause":
                        AudioManager.playAudio("pause_button_click");
                        break;
                    case "Stop":
                        AudioManager.playAudio("stop_button_click");
                        break;
                    default:
                        // 播放默认按钮点击音效
                        AudioManager.playButtonClickAudio();
                        break;
                }
            } else {
                // 如果没有 Label 组件,播放默认按钮点击音效
                AudioManager.playButtonClickAudio();
            }

            // 调用原始的 _onTouchEnded 方法
            originalOnTouchEnded.call(this, event);
        };
    }
}

// 在游戏初始化时调用这个方法
CustomButton.hackCCButtonToPlayAudio();

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

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

相关文章

matlab 计算导数

边界提取 一、算法原理1、主要函数2、参考文献二、代码实现三、结果展示四、参考链接本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫。 一、算法原理 1、主要函数 Y = diff(X)计算沿大小不等于 1 的第一个数组维度的 X X…

计算机网络 —— 基本概念

基本概念 1. 通信协议2. 面向连接 v.s. 面向无连接3. 电路交换 v.s. 分组交换4. 单工通信 v.s. 双工通信 1. 通信协议 通信协议就是计算机与计算机之间通过网络实现通信时事先达成的一种“约定”。这种“约定”使那些由不同厂商的设备、不同的CPU 以及不同的操作系统组成的计算…

黑芝麻科技A1000简介

文章目录 1. A1000 简介2. 感知能力评估3. 竞品对比4. 系统软件1. A1000 简介

pdf合并,pdf合并成一个pdf,pdf合并在线网页版

在处理pdf文件的过程中,有时我们需要将多个pdf文件合并成一个pdf文件。作为一名有着丰富计算机应用经验的技术博主,我将为您详细介绍如何将多个pdf文件合并成一个pdf文件。 pdf合并方法:使用, “轻云处理pdf官网” 打开 “轻云处…

有序充电在新能源行业的前景与应用

作为新能源汽车的基础动力装置,交流充电桩也是可以促使新能源汽车正常行驶的关键内容。近年来我国新能源汽车的增长速度出现明显的上升趋势,但是其充电桩的发展还比较缓慢。目前在充电桩系统设计期间仍存在一些问题,主要表现在充电设施短缺、…

负载均衡器有什么用?

负载均衡器有什么用? 负载均衡器是一种在多个服务器之间分配网络或应用程序流量的设备或软件应用程序。其主要目的是确保没有一台服务器承担过多的需求,从而提高应用程序的响应速度和可用性。 在计算机发展的早期,负载均衡是一个手动过程。…

python-斐波那契数列

[题目描述] 斐波那契数列是指这样的数列:数列的第一个和第二个数都为 1,接下来每个数都等于前面 2个数之和。 给出一个正整数 a,要求斐波那契数列中第 a 个数是多少。输入: 第 1 行是测试数据的组数 n,后面跟着 n 行输…

版本控制工具-git分支管理

目录 前言一、git分支管理基本命令1.1 基本命令2.1 实例 二、git分支合并冲突解决三、git merge命令与git rebase命令对比 前言 本篇文章介绍git分支管理的基本命令,并说明如何解决git分支合并冲突,最后说明git merge命令与git rebase命令的区别。 一、…

Flink作业执行之 4.JobGraph

Flink作业执行之 4.JobGraph 1. 入口 前文了解了由Transformation到StreamGraph的过程,StreamGraph即作业的逻辑拓扑结构。 生成逻辑结构后,接下来的操作往往是对逻辑结构的优化。在很多组件中都是这样的处理,如hive、spark等都会执行“逻辑…

【python】OpenCV—QR Code

文章目录 1 QR Code2 准备工作3 生成 QR 码4 读取 QR 码5 与 Zbar 比较 1 QR Code QR Code(Quick Response Code)是一种二维条码,由日本Denso-Wave公司于1994年发明。QR Code的主要特点是存储信息量大、编码范围广、容错能力强、识读速度快&…

Docker Compose 一键快速部署 RocketMQ

Apache RocketMQ是一个开源的分布式消息中间件系统,最初由阿里巴巴开发并贡献给Apache软件基金会。RocketMQ提供了高性能、高可靠性、高扩展性和低延迟的消息传递服务,适用于构建大规模分布式系统中的消息通信和数据同步。 RocketMQ支持多种消息模型&am…

通讯录管理系统——显示联系人

功能描述:显示通讯录中已有的联系人信息 显示联系人实现步骤: 1.封装显示联系人函数 2.测试显示联系人功能 一、封装显示联系人函数 思路:判断如果当前通讯录中没有人员,就提示记录为空;人数大于0,显示…

DataWhale-吃瓜教程学习笔记(四)

学习视频:第3章-二分类线性判别分析_哔哩哔哩_bilibili 西瓜书对应章节: 3.4 文章目录 - 算法原理- 损失函数推导-- 异类样本中心尽可能远-- 同类样本方差尽可能小-- 综合 知识点补充 - 二范数二范数(2-norm)详解定义几何意义性质…

【单片机毕业设计10-基于stm32c8t6的智能窗帘/窗户系统】

【单片机毕业设计10-基于stm32c8t6的智能窗帘/窗户系统】 前言一、功能介绍二、硬件部分三、软件部分总结 前言 🔥这里是小殷学长,单片机毕业设计篇10基于stm32的智能窗帘/窗户系统 🧿创作不易,拒绝白嫖可私 一、功能介绍 -------…

Tensorflow入门实战 T06-Vgg16 明星识别

目录 1、前言 2、 完整代码 3、运行过程结果 4、遇到的问题 5、小结 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 | 接辅导、项目定制 1、前言 这周主要是使用VGG16模型,完成明星照片识别。 2、 完整代…

[XYCTF新生赛2024]-PWN:EZ2.0?(arm架构,arm架构下的系统调用)

查看保护 查看ida 完整exp: from pwn import*pprocess(./arm) premote(gz.imxbt.cn,20082) svc0x0001c58c mov_r2_r4_blx_r30x00043224 pop_r70x00027d78 pop_r40x000104e0 pop_r30x00010160 pop_r10x0005f824 pop_r00x0005f73c sh0x0008A090payloadba*0x44 payloa…

探索高效开发神器:Blackbox AI(免费编程助手)

人不走空 🌈个人主页:人不走空 💖系列专栏:算法专题 ⏰诗词歌赋:斯是陋室,惟吾德馨 🤖 想要代码生成?👌 💬 需要和AI聊天解决难题?&#…

完全离线的本地问答模型LocalGPT如何实现无公网IP远程连接提问

文章目录 前言环境准备1. localGPT部署2. 启动和使用3. 安装cpolar 内网穿透4. 创建公网地址5. 公网地址访问6. 固定公网地址 前言 本文主要介绍如何本地部署LocalGPT并实现远程访问,由于localGPT只能通过本地局域网IP地址端口号的形式访问,实现远程访问…

[C语言]指针

一、指针简介 1、指针(Pointer)是C语言的一个重要知识点,其使用灵活、功能强大,是C语言的灵魂 2、指针与底层硬件联系紧密,使用指针可操作数据的地址,实现数据的间接访问 3、计算机存储机制 4、定义指针 (1&#x…