Babylon.js行为编写及使用参考

news2025/1/9 18:10:06

        在 Babylon.js 中,行为(Behavior,这个和Unity的继承自MonoBehavior的组件实在是有点儿像)的编写非常中要,这里举一个例子:

// RotateBehavior.js
class RotateBehavior {
    constructor() {
        this.rotateEnabled = true;
        this.rotationSpeed = 60; // 默认每秒旋转 60 度
    }

    init() {
        console.log("旋转行为初始化");
    }

    // Babylon.js 会自动调用这个方法来附加行为
    attach(target) {
        this.target = target;
        this.target.onBeforeRenderObservable.add(() => {
            if (this.rotateEnabled) {
                this.target.rotation.y += BABYLON.Tools.ToRadians(this.rotationSpeed) * this.target.getScene().getEngine().getDeltaTime() / 1000;
            }
        });
    }

    // Babylon.js 会自动调用这个方法来分离行为
    detach() {
        if (this.target) {
            this.target.onBeforeRenderObservable.remove(this.target.onBeforeRenderObservable.getObservers().find((observer) => observer.callback === this.update));
            this.target = null;
        }
        console.log("旋转行为分离");
    }

    setRotateEnable(enable) {
        this.rotateEnabled = enable;
    }

    setRotationSpeed(speed) {
        this.rotationSpeed = speed;
    }
}

export default RotateBehavior;

       上面这个行为让mesh可以按y轴每秒旋转特定的角度。其中

this.rotateEnabled = true;
this.rotationSpeed = 60; // 默认每秒旋转 60 度

这两行代码写到 init 方法中也可以。 

        需要说明的是,以下三个方法是必须实现的,他们分别是:

  •  init() ,这个方法会在行为被附加到目标之前调用。
  • attach(target) ,这个方法会在行为被附加时调用。
  • detach(),这个方法会在行为被分离时调用。

以下是一个使用该行为的参考代码:

import * as BABYLON from 'babylonjs';
import RotateBehavior from './RotateBehavior';

// 创建场景和引擎
var createScene = function () {
    var canvas = document.getElementById("renderCanvas");
    var engine = new BABYLON.Engine(canvas, true);
    var scene = new BABYLON.Scene(engine);

    // 创建摄像机
    var camera = new BABYLON.ArcRotateCamera("camera", Math.PI / 2, Math.PI / 4, 10, BABYLON.Vector3.Zero(), scene);
    camera.attachControl(canvas, true);

    // 创建一个简单的立方体
    var box = BABYLON.MeshBuilder.CreateBox("box", { size: 2 }, scene);
    box.position.y = 1; // 将立方体稍微抬高,避免与地面重叠

    // 创建旋转行为实例并附加到立方体上
    var rotateBehavior = new RotateBehavior();
    box.addBehavior(rotateBehavior);

    // 提供一个按钮来控制旋转的启停和速度
    var advancedTexture = BABYLON.GUI.AdvancedDynamicTexture.CreateFullscreenUI("UI");

    var toggleRotateButton = BABYLON.GUI.Button.CreateSimpleButton("toggleRotate", "Toggle Rotate");
    toggleRotateButton.width = "120px";
    toggleRotateButton.height = "40px";
    toggleRotateButton.color = "white";
    toggleRotateButton.background = "green";
    toggleRotateButton.onPointerClickObservable.add(() => {
        rotateBehavior.setRotateEnable(!rotateBehavior.rotateEnabled);
        toggleRotateButton.text = rotateBehavior.rotateEnabled ? "Stop Rotate" : "Start Rotate";
    });
    advancedTexture.addControl(toggleRotateButton);

    var setSpeedButton = BABYLON.GUI.Button.CreateSimpleButton("setSpeed", "Set Speed to 120");
    setSpeedButton.width = "120px";
    setSpeedButton.height = "40px";
    setSpeedButton.color = "white";
    setSpeedButton.background = "blue";
    setSpeedButton.onPointerClickObservable.add(() => {
        rotateBehavior.setRotationSpeed(120);
    });
    advancedTexture.addControl(setSpeedButton);

    // 渲染场景
    engine.runRenderLoop(function () {
        scene.render();
    });

    // 处理窗口大小变化
    window.addEventListener("resize", function () {
        engine.resize();
    });

    return scene;
};

// 创建场景
var scene = createScene();

        这里将行为附加到mesh上的方法有两种,以上例子中写的是:

box.addBehavior(rotateBehavior);

        其实写成以下形式也是可以的:

rotateBehavior.attach(box, scene, engine);

        但是Babylon推荐的是第一种,因为它提供了一些内置的管理和生命周期处理功能,而Behavior.attch这个方法是需要手动管理的,虽然灵活性比较高,但对开发者要求也较高,不建议初学者使用。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【HarmonyOS NEXT】鸿蒙应用使用后台任务之长时任务,解决屏幕录制音乐播放等操作不被挂起

【HarmonyOS NEXT】鸿蒙应用使用后台任务之长时任务,解决屏幕录制音乐播放等操作不被挂起 一、前言 1.后台是什么? 了解后台任务和长时任务前,我们需要先明白鸿蒙的后台特性:所谓的后台,指的是设备返回主界面、锁屏、…

【JVM】总结篇之垃圾回收★

文章目录 为什么需要GC垃圾回收算法★垃圾判断阶段引用计数算法可达性分析GC roots为什么会stop world?垃圾清除阶段标记-清除(Mark - Sweep)算法复制(Copying)算法标记-压缩(或标记-整理、Mark - Compact)算法分代收集算法增量收集(Incremental Collecting)算法分区算…

【Redis源码】 RedisObject结构体

【Redis源码】 RedisObject结构体 文章目录 【Redis源码】 RedisObject结构体概要1. redis object 由来2. 通过汇编代码分析3. 总结 概要 博主这里从redis object由来,和从底层内存分配角度进行讲解哦,小伙伴们自行选择读取 1. redis object 由来 ​ …

Ungoogled Chromium127 编译指南 MacOS 篇(二)- 项目要求

1. 引言 在开始编译 Ungoogled Chromium 之前,我们需要确保系统满足所有必要的硬件和软件要求。由于浏览器编译是一个资源密集型的任务,合适的硬件配置和完整的软件环境至关重要。本文将详细介绍编译 Ungoogled Chromium 所需的各项要求。 2. 硬件要求…

专家混合(MoE)大语言模型:免费的嵌入模型新宠

专家混合(MoE)大语言模型:免费的嵌入模型新宠 今天,我们深入探讨一种备受瞩目的架构——专家混合(Mixture-of-Experts,MoE)大语言模型,它在嵌入模型领域展现出了独特的魅力。 一、M…

【Golang 面试题】每日 3 题(二十四)

✍个人博客:Pandaconda-CSDN博客 📣专栏地址:http://t.csdnimg.cn/UWz06 📚专栏简介:在这个专栏中,我将会分享 Golang 面试中常见的面试题给大家~ ❤️如果有收获的话,欢迎点赞👍收藏…

TCP Analysis Flags 之 TCP Retransmission

前言 默认情况下,Wireshark 的 TCP 解析器会跟踪每个 TCP 会话的状态,并在检测到问题或潜在问题时提供额外的信息。在第一次打开捕获文件时,会对每个 TCP 数据包进行一次分析,数据包按照它们在数据包列表中出现的顺序进行处理。可…

Docker 使用Dockerfile创建镜像

创建并且生成镜像 在当前目录下创建一个名为Dockerfile文件 vi Dockerfile填入下面配置 # 使用 CentOS 作为基础镜像 FROM centos:7# 设置工作目录 WORKDIR /app# 复制项目文件到容器中 COPY bin/ /app/bin/ COPY config/ /app/config/ COPY lib/ /app/lib/ COPY plugin/ /a…

Matlab 数据处理与可视化的多元拓展应用(具体代码分析)

一、代码整体功能概述: 该代码主要实现了以下几个功能: 从文件(part1.txt)中读取数据,并提取第二列数据,将其存储在 originalColumnData 中。对原始数据进行可视化,包括绘制置零前数据的折线图…

Oracle OCP考试常见问题之线上考试流程

首先要注意的是:虽然Oracle官方在国际上取消了获得OCP认证需要培训记录的要求,但在中国区,考生仍然需要参加Oracle的官方或者其合作伙伴组织的培训,并且由Oracle授权培训中心向Oracle提交学员培训记录。考生只有在完成培训并通过考…

第2章 市场走势的分类与组合

本章主要讨论市场中走势的分类与组合,从基本假设出发,对市场的走势状态进行分类,探讨不同的走势组合和走势组合分类,以深刻理解走势。 2.1 走势分类 根据第一章市场的基本假设三,走势包含无序运动状态(混…

【Excel/WPS】根据平均值,生成两列/多列指定范围的随机数/随机凑出两列数据

原理就是通过随机生成函数和平均值函数。 适用场景:在总体打分后,需要在小项中随机生成小分数 第一列:固定的平均值A2第二列: RANDBETWEEN(A2-10,A210)第三列:根据第二列用平均值函数算除 A2*2-B2这是随机值1的公式&am…

STM32裸机开发转FreeRTOS教程

目录 1. 简介2. RTOS设置(1)分配内存(2)查看任务剩余空间(3)使用osDelay 3. 队列的使用(1)创建队列(1)直接传值和指针传值(2)发送/接收…

Golang的网络安全漏洞检测

Golang的网络安全漏洞检测 一、网络安全意识的重要性 在当今网络高度发达的环境下,网络安全问题变得异常突出。黑客利用各种手段对网络系统进行攻击,企图窃取数据、篡改信息、瘫痪服务等,因此网络安全成为全球关注的焦点。在这种环境下&#…

oscp备考 oscp系列——Kioptix Level 1靶场 古老的 Apache Vuln

目录 前言 1. 主机发现 2. 端口扫描 3. 指纹识别 4. 目录扫描 5. 漏洞搜索和利用 前言 oscp备考,oscp系列——Kioptix Level 1靶场 Kioptix Level 1难度为简单靶场,主要考察 nmap的使用已经是否会看输出,以及是否会通过应用查找对应漏…

git的rebase和merge的区别?

B分支从A分支拉出 1.git merge 处于A分支执行,git merge B分支:相当于将commit X、commit Y两次提交,作为了新的commit Z提交到了A分支上。能溯源它真正提交的信息。 2.git rebase 处于B分支,执行git rebase A分支,B分支那边复…

ansible-性能优化

一. 简述: 搞过运维自动化工具的人,肯定会发现很多运维伙伴们经常用saltstack和ansible做比较,单从执行效率上来说,ansible确实比不上saltstack(ansible使用的是ssh,salt使用的是zeromq消息队列[暂没深入了解]),但其实…

Pytest钩子函数,测试框架动态切换测试环境

在软件测试中,测试环境的切换是个令人头疼的问题。不同环境的配置不同,如何高效切换测试环境成为许多测试开发人员关注的重点。你是否希望在运行测试用例时,能够动态选择测试环境,而不是繁琐地手动修改配置? Pytest 测…

【RK3568笔记】Android修改开机动画

概述 Android 的开机动画是由一系列连续的 PNG 图片作为帧组成的动画形式,不是一张 GIF 图片。将各帧 PNG 图片以压缩方式进行保存(压缩方式要求是存储压缩),并将保存的文件名命名为 bootanimation.zip,这个 bootanim…

华为路由器、交换机、AC、新版本开局远程登录那些坑(Telnet、SSH/HTTP避坑指南)

关于华为设备远程登录配置开启的通用习惯1、HTTP/HTTPS相关服务 http secure-server enablehttp server enable 2、Telnet服务telnet server enable3、SSH服务stelnet server enablessh user admin authentication-type password 「模拟器、工具合集」复制整段内容 链接&…