【WEB前端2024】开源智体世界:乔布斯3D纪念馆-第22课-烟花插件的制作

news2025/1/13 11:01:40

【WEB前端2024】开源智体世界:乔布斯3D纪念馆-第22课-烟花插件的制作

使用dtns.network德塔世界(开源的智体世界引擎),策划和设计《乔布斯超大型的开源3D纪念馆》的系列教程。dtns.network是一款主要由JavaScript编写的智体世界引擎(内嵌了three.js编辑器的定制版-支持以第一视角游览3D场馆),可以在浏览器和node.js、deno、electron上运行,它是一个跨平台的软件,支持多个操作系统使用!

下面分为几步介绍,如何基于dtns.plugin实现烟花插件的制作。该《烟花插件》采用开源的js-canvas绘制燃放烟花的特效。通过dtns.plugin(基于vue2.x版本构建《烟花插件》),通过npm build lib编译生成index.js,将index.js和index.json配置文件,压缩生成dpkg的类似各类小程序安装包的插件。

基于js原生开发的dtns.plugin插件,拥有移植方便,使用简单,易于传播的特点。并且上手简单,特别容易开发。是除了poplang智体编程之外,极好的插件开发技术栈。可以轻松地在dtns.network智体世界和dtns.connector客户端中,实现各类轻应用(例如dpkg、xverse、xcard等)开发的利器!

这也是构建dtns.os(智体OS)的利器!

第一步:打开头榜页面,找到“烟花插件-4”

在这里插入图片描述
注:第一次点击会下载dpkg插件文件(并提示文件保存路径——游览器);第二次点击会进入“烟花插件”页面(/firework路径,后面会讲到如何配置这个页面路由路径)

第二步:点击“烟花插件”,查看烟花燃放动画效果

在这里插入图片描述
注:由于顶部无【返回】按钮,须通过游览器的回退按钮或手机上的返回触摸键返回头榜页面。

第三步:打开vscode中的dtns.plugin文件夹,了解dpkg插件开发原理

在这里插入图片描述
注:如上图所示,在dtns.plugin/pkgs/pages/firework/FireWork.vue中查看到template标签,继续向下滑动,可以看到这个是一个典型的vue文件(如下图所示)
在这里插入图片描述
注:可以看到vue模板template的name为FireWork(插件名称,后续引入这个component组件,需要用到,并且在dpkg插件的配置文件index.json中也需要声明)

第四步:查看dtns.plugin/pkgs/index.js文件,了解插件install安装到vue全局组件的机制和配置

在这里插入图片描述
注:须将刚才的Firework.vue组件,导入为FireWork变量,并且存放于components数组中,以便install函数安装(在vue中安装为全局组件,以方便导入dtns.connector后能按组件名称(name)进行加载插件。

第五步:查看dtns.plugin插件工程下面的package.json——可看到npm run lib指令将刚才的FireWork.vue插件编译为库文件

在这里插入图片描述
注:通过上述的scripts中的指令,可以看到运行npm run lib,即可编译生成index.js库文件(后续改名为index.js插件文件)

在vscode终端中运行npm run lib指令后,生成lib\dtns-plugin.um.min.js库文件(如下图所示)
在这里插入图片描述
注:后续步骤,会将这个文件修改为index.js的dpkg插件js文件。

第六步:通过demo.html测试刚编译的js插件lib库文件是否可用

在这里插入图片描述
注:打开demo.html,可以看到将./lib/dtns-plugin.um.js库文件导入,并引入了vue.min.js库文件,然后在div-id=”app”的html元素正方,通过fire-work标签引入了名称为FireWork的组件。这是一个典型的vue2.x的web应用。Vue.js开发者应该很快能理解它。

第七步:双击demo.html,查看插件运行结果(如下图所示)

在这里插入图片描述
打开刚才的dtns.plugin/demo.html,可以看到如上效果图

第八步:在dtns.plugin/lib路径下,复制dtns-plugin.um.min.js文件

在这里插入图片描述
注:亦可复制dtns-plugin.um.js文件(但是文件未经压缩,会导致插件dpkg文件变大)

第九步:将此文件复制至dtns.plugin/dpkg/firework路径下,将dtns-plugin.um.min.js改名为index.js目标库文件名

在这里插入图片描述
注:只有index.js才能被dtns.connector真正识别并导入插件成功。

第十步:点击dpkg/index.json,将其内容修改如下图所示

在这里插入图片描述
注:这是一个[]的数组,里面包含了一个{}json对象

注2:属性name是插件的名称;path代表了插件加载后打开的路径,workPath是代表在ibchat智体IB中输入指令“firework”(“word”属性的值)后路径的路径。

注3:url属性务必为刚才的vue组件名“FIreWork”——写错将导致该插件无法被识别并导入——并且type属性须为“name”,不能为vue或其它值。

注4:其它的title、desc、author、date按照开发者实际情况填写即可。

第十一步:将index.js和index.json不加文件夹情况下,直接压缩为zip压缩包,并将.zip文件格式修改为.dpkg,成功构建真正的dpkg的轻应用插件(类似各类小程序包)

在这里插入图片描述
注:将index.js和index.json直接右键菜单,选择压缩文件为zip。然后将.zip文件后缀修改为.dpkg(注意,有些操作系统会隐藏这个文件格式后缀,将在【文件夹选项-查看文件格式】等方式实现文件后缀的查看和修改为.dpkg。

第十二步:回到dtns.connector德塔世界连接器,点击头榜右上角+号,进入发布头榜页面

在这里插入图片描述
点击+号后,进入发布头榜页面(如下图所示)
在这里插入图片描述
注:将刚才压缩生成的firework-4.dpkg轻应用包,以文件方式上传。并将头榜内容设置为“烟花插件-4”,并点击右上角“确认”按钮,发布插件成功!

第十三步:回到头榜页面,找到《3D纪念馆-购买烟花》的xverse轻应用,点击右上角…,进入头榜编辑器,然后点击下方的“编辑xverse轻应用源码”进入3D场景编辑器

在这里插入图片描述
进入3D场景编辑器(如下图所示)
在这里插入图片描述
注:通过滚动球控制玩家视角正对着“乔布斯传”3D摆件正前方。

第十四步:点击3D摆件右侧属性面板的“脚本”-编辑按钮,打开poplang智体编程编辑器

在这里插入图片描述
注:我们看到,通过$.g_firework_onload实现了对烟花插件的全局函数的调用——以实现在3D纪念馆中燃放烟花。

注2:通过ib3.file.go obj_file* onflag实现了烟花插件的预加载(不须人工点击,实现自动安装烟花插件——后续的dtns.os智体操作系统,亦可通过该指令实现了插件的自动化部署和全局函数的调用)

第十五步:在dtns.plugin的vscode工程中,我们通过查看FireWork.vue源码,找到了全局函数window.g_firework_onload的出处(如下图所示)

在这里插入图片描述

第十六步:点击顶部的“启动(自由视角)”预览3D场馆,点击中间的“乔布斯传”3D摆件,出现燃放烟花动画效果

在这里插入图片描述
注:点击屏幕中间,这些烟花特效会关闭(亦是在FireWork.vue中实现了该事件的绑定)

通过上述16步,我们成功完成了“烟花插件”的制作。通过dtns.plugin插件引擎,我们成功的构建了dpkg插件文件,从而直接通过头榜上传和头榜支付购买烟花插件.dpkg文件的方式,为dtns.connector德塔世界连接器融入了烟花插件功能(并实现了3D场馆中调用插件全局函数)。最终实现了3D场馆的摆件点击播放烟花插件动画,完整实现了一个从vue插件构建,上传发布,文件锁售卖插件,在poplang智体编程场景中调用全局函数使用它的完整闭环。

整个dpkg插件的体验非常完整。可以看到,使用dpkg和dtns.plugin插件系统,可轻松构建dtns.connector的轻应用插件生态。插件的开发、部署、上传、体验、销售、购买均非常方便。非常适合构建【插件商店】生态、插件开发者生态、插件开源生态等。

总结而言:dtns.connector德塔世界连接器,拥有了dpkg轻应用生态(融入了vue.js插件开发生态),变得更像是一个基于游览器原生应用的操作系统:可命名为dtns.os操作系统。所有插件和项目均为开源,欢迎体验!

注:dtns.network德塔世界(开源的智体世界引擎)是在github和gitee上开源的项目!

开源地址:

github地址:https://github.com/dtnsman/dtns

Gitee地址:https://github.com/dtnsman/dtns

官方文档:https://dtns.network.yunapi.org

加入QQ群:279931001

加入微信群:
在这里插入图片描述

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

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

相关文章

VBA在Excel中部首组查字法的应用

VBA在Excel中部首组查字法的应用 文章目录 前言一、网站截图二、操作思路三、代码1.创建数据发送及返回方法2.创建截取字符串中的数值的方法3.获取部首对应的编码4.获取特定部首的汉字运行效果截图前言 使用汉语字典查生字、生词,多用拼音查字法和部首查字法。以前都是用纸质…

2024深圳杯数学建模C题参考论文24页+完整代码数据解题

一、问题研究 24页参考论文: 【编译器识别】2024深圳杯C题24页参考论文1-3小问完整解题代码https://www.jdmm.cc/file/2710545/ 为了回答这些问题,我们需要进行一系列的编译实验、分析编译结果,并构建判别函数。以下是对这些问题的初步分析…

Weblogic SSRF

1 SSRF漏洞概述 SSRF漏洞通常是由于服务端提供了从其他服务器应用获取数据的功能,并且没有对目标地址进行过滤与限制。攻击者可以利用这个漏洞,通过篡改获取资源的请求发送给服务器,服务器在没有发现这个请求是非法的情况下,会以…

精酿啤酒:精酿文化的传承者与创新者

在啤酒的世界中,精酿啤酒是一种与众不同的文化现象。这种文化源于对啤酒品质的追求和对传统工艺的尊重,但在不断发展中也不断涌现出创新。作为精酿啤酒的品牌,Fendi club啤酒不仅是这种文化的传承者,更是创新者。 Fendi club啤酒始…

宠物管理系统带万字文档

文章目录 宠物管理系统一、项目演示二、项目介绍三、19000字论文参考四、部分功能截图五、部分代码展示六、底部获取项目源码和万字论文参考(9.9¥带走) 宠物管理系统 一、项目演示 宠物管理系统 二、项目介绍 基于springbootvue的前后端分离…

第二步 完善MBR

文章目录 前言一、什么是MBR?二、我们需要什么样的MBR?三、设计我们的MBR!1、打印“1 MBR”2、加载次引导程序——loader 四、实践检验! 查看系列文章点这里: 操作系统真象还原 前言 在上一篇文章 第一步 从启动BIOS开…

Centos7 配置 DNS服务器

Centos 7 配置DNS服务器 环境描述: 一台服务器和一台用于测试的客户机 服务器IP:192.168.200.132 客户机IP:192.168.200.143 服务器配置 yum install bind bind-utils -y #安装软件包vim /etc/named.conf //编辑named主配置文件listen-on p…

【校园论坛系统】分站式后台,多城市圈子论坛,校园圈子交流平台,二手发布市场,校园圈子论坛系统

简述 校园论坛系统是为学生们提供一个交流、分享信息、互相帮助的平台。它通常包括了各种分类的版块,例如学习交流、社团活动、二手交易、失物招领等等。用户可以在论坛上发帖,回复他人的帖子,也可以私信其他用户。此外,管理员还…

AIGC——Instant-Style文本到图像生成中的样式保留算法解析

0.概述 在过去的几年中,基于调整的扩散模型在广泛的图像个性化和定制任务中取得了显着的进展。然而,尽管有潜力,当前基于调整的扩散模型在生成和生成风格一致的图像方面仍然面临着一系列复杂的挑战,其背后可能有三个原因。首先&a…

单链表题-ysf-反转-中间节点-回文-合并-分割

环形链表的约瑟夫问题_牛客题霸_牛客网 经典的约瑟夫环 #include <stdint.h> #include <stdlib.h> //创建链表 typedef struct ListNode ListNode;ListNode* buyNode(int x){ListNode* newNode(ListNode*)malloc(sizeof(ListNode));if(newNodeNULL){exit(1);}newN…

特斯拉FSD的硬件演进与模型压缩技术解析

引言 随着自动驾驶技术的迅速发展&#xff0c;特斯拉的全自动驾驶&#xff08;FSD&#xff09;系统也在不断进化。最近&#xff0c;特斯拉开始采用端到端的模型来优化其FSD算法&#xff0c;这种变革引发了广泛关注。本文将探讨特斯拉FSD在车载计算能力和模型压缩技术方面的最新…

7集成学习评分卡

集成学习评分卡 学习目标 知道LightGBM基本原理掌握使用lightGBM进行特征筛选的方法1 Gradient Boosting算法回顾 Gradient Boosting 基本原理 训练一个模型m1,产生错误e1针对e1训练一个模型m2,产生错误e2针对e2训练第三个模型m3,产生错误e3 …最终预测结果是:m1+m2+m3+…GB…

基于死区补偿的永磁同步电动机矢量控制系统simulink仿真模型

整理了基于死区补偿的永磁同步电动机矢量控制系统simulink仿真&#xff0c;该模型使用线性死区补偿的PMSM矢量控制算法进行仿真&#xff0c;使用Foc电流双闭环 。 1.模块划分清晰&#xff0c;补偿前后仿真有对比&#xff0c;易于学习; 2.死区补偿算法的线性区区域可调; 3.自…

【计算机网络】HTTP协议详解实战抓包分析教程

文章目录 1.HTTP简介2.HTTP报文的结构3.HTTP协议中空行的作用4.uri和url的区别5.HTTP请求5.1 HTTP请求方法5.2 HTTP请求报头 6.HTTP响应6.1 状态码 7.HTTP位于应用层(基于TCP)8.非持久和持久连接8.1 非持久连接8.2 持久连接 1.HTTP简介 HTTP&#xff08;Hypertext Transfer Pr…

【考研数学】跟「武忠祥」真不如「张宇」吗??

现在是张宇老师强势版本&#xff01; 24年之前&#xff0c;你说跟武忠祥老师好&#xff0c;我非常赞成&#xff0c;但是24年很多同学考完出来都说&#xff0c;早知道跟张宇了&#xff0c;都说24年考研数学偏&#xff0c;怪&#xff0c;难&#xff0c;计算量还大。 武忠祥老师…

刷题之字母异位词(leetcode 哈希表)

https://leetcode.cn/problems/group-anagrams/ class Solution { public:vector<vector<string>> groupAnagrams(vector<string>& strs) {unordered_map<string,vector<string>>map;//哈希表键为排序后或者处理后的字符串&#xff0c;值为某…

Web课外练习7

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>照片墙</title><style>body {display: …

P9748 [CSP-J 2023] 小苹果:做题笔记

目录 P9748 [CSP-J 2023] 小苹果 思路 代码 P9748 [CSP-J 2023] 小苹果 P9748 [CSP-J 2023] 小苹果 思路 先写几个看看规律 题意我们能看出来是三个三个一组的&#xff0c;然后每次取走的都是三个里面的第一个。我们应该很容易想到如果一轮的总数是三的倍数的话&#xff0…

Linux查看进程命令ps和top

Linux 是一种自由和开放源代码的操作系统&#xff0c;它的使用在全球范围内非常广泛。在 Linux 中&#xff0c;进程是操作系统中最重要的组成部分之一&#xff0c;它代表了正在运行的程序。了解如何查看正在运行的进程是非常重要的&#xff0c;因为它可以帮助你了解系统的运行状…

langchain_community FAISS保存与加载faiss index

参考: https://github.com/langchain-ai/langchain/issues/18285 https://api.python.langchain.com/en/latest/vectorstores/langchain_community.vectorstores.faiss.FAISS.html#langchain_community.vectorstores.faiss.FAISS 1、保存save_local import pandas as pd ##…