Eva.js是什么(互动小游戏开发)
前言
Eva.js 是一个专注于开发互动游戏项目的前端游戏引擎。
-
易用:Eva.js 提供开箱即用的游戏组件供开发人员立即使用。是的,它简单而优雅!
-
高性能:Eva.js 由高效的运行时和渲染管道 (Pixi.JS) 提供支持,这使得释放设备的全部潜力成为可能。
-
可扩展:得益于 ECS(实体-组件-系统)架构,你可以通过高度可定制的 API 扩展您的需求。唯一的限制是你的想象力!
一、概念
Eva.js 是一个用于构建前端应用的 JavaScript 框架。它基于 React,提供了一套可扩展的架构和工具,旨在帮助开发者更高效地构建复杂的应用。
Eva.js 的核心概念包括:
-
组件化:Eva.js 鼓励开发者将应用拆分为多个可重用的组件,每个组件负责自己的状态和逻辑。组件之间可以通过 props 和 events 进行通信。
-
状态管理:Eva.js 提供了一套简单但强大的状态管理机制。通过定义状态模型和更新规则,开发者可以方便地管理应用的状态,实现组件之间的数据共享。
-
数据驱动:Eva.js 强调使用数据驱动的方式进行开发。开发者通过绑定数据和事件,自动响应数据的变化,从而实现 UI 的更新。
-
插件化:Eva.js 支持插件机制,开发者可以根据需求扩展框架的功能。插件可以用来处理数据持久化、网络请求、路由等方面的功能。
-
轻量灵活:Eva.js 的设计目标是轻量、灵活和易于使用。它提供了一些常用的功能和工具,但是没有过多的约束和限制,开发者可以根据自己的需求进行自定义。
Eva.js 是一个面向组件化、数据驱动的前端框架,旨在提高开发效率和代码质量。它的概念和理念与其他类似框架相似,但也有自己的特色和优势。
二、使用
提供两种使用方式,一种是基于NPM,另外一种直接在浏览器中使用外链JS文件。
- 基于NPM
npm i @eva/eva.js @eva/plugin-renderer @eva/plugin-renderer-img --save
- 在浏览器中
<script src="https://unpkg.com/@eva/eva.js@1.0.4/dist/EVA.min.js"></script>
三、案例
案例1
<canvas id="canvas" ></canvas>import { Game, GameObject, resource, RESOURCE_TYPE } from '@eva/eva.js';
import { RendererSystem } from '@eva/plugin-renderer';
import { Img, ImgSystem } from '@eva/plugin-renderer-img';resource.addResource([{name: 'imageName',type: RESOURCE_TYPE.IMAGE,src: {image: {type: 'png',url:'https://gw.alicdn.com/tfs/TB1DNzoOvb2gK0jSZK9XXaEgFXa-658-1152.webp',},},preload: true,},
]);const game = new Game({systems: [new RendererSystem({canvas: document.querySelector('#canvas'),width: 750,height: 1000,}),new ImgSystem(),],
});const image = new GameObject('image', {size: { width: 750, height: 1319 },origin: { x: 0, y: 0 },position: {x: 0,y: -319,},anchor: {x: 0,y: 0,},
});image.addComponent(new Img({resource: 'imageName',})
);game.scene.addChild(image);
案例2
一个简单的 Eva.js 案例代码示例:
// 导入 Eva.js 相关模块
import React from 'react';
import { createStore, createModel } from 'eva.js';// 创建状态模型
const counterModel = createModel({namespace: 'counter',state: {count: 0},actions: {increment(state) {return {...state,count: state.count + 1};},decrement(state) {return {...state,count: state.count - 1};}}
});// 创建应用主界面组件
function App() {// 获取状态数据和操作方法const { state, actions } = counterModel.useModel();return (<div><h1>Counter: {state.count}</h1><button onClick={actions.increment}>Increment</button><button onClick={actions.decrement}>Decrement</button></div>);
}// 创建应用实例
const app = createStore({ models: [counterModel] });// 渲染应用
app.render(<App />);
上述代码中,我们首先导入了 Eva.js 相关的模块。然后,创建了一个名为 counterModel 的状态模型,其中定义了初始状态和操作方法。接着,编写了一个名为 App 的组件,通过 counterModel.useModel() 获取状态数据和操作方法,并在界面中显示计数器的值和两个按钮。最后,创建了一个应用实例,并渲染了 App 组件。
这段代码的功能是实现一个简单的计数器应用,点击增加和减少按钮可以改变计数器的值。这个案例展示了 Eva.js 的组件化、状态管理和数据驱动的特点。请注意,这只是一个简单的示例,实际项目中可能还需要处理更复杂的逻辑和交互。
四、优缺点
Eva.js 是一个基于 React 的状态管理库,具有以下优点和缺点:
优点
- 简单易用:Eva.js 提供了简洁的 API,使得状态管理变得简单直观。
- 数据驱动:Eva.js 强调数据驱动的开发模式,通过声明式的方式管理状态和组件之间的关系,使得代码更加清晰和易于维护。
- 组件化:Eva.js 支持将状态模型和 UI 组件进行分离,实现了组件化的开发模式,提高了代码的可复用性和可维护性。
- 状态共享:Eva.js 可以将状态模型共享给多个组件使用,避免了组件之间的状态传递和同步的繁琐操作。
- 插件扩展:Eva.js 提供了插件机制,可以自定义扩展各种功能,例如异步处理、数据持久化等。
缺点
- 学习曲线:对于初学者来说,理解和掌握 Eva.js 的概念和使用方式可能需要一定的学习成本。
- 可能增加复杂性:Eva.js 的引入可能会增加项目的复杂性,尤其是对于小规模和简单的项目,可能并不需要引入额外的状态管理库。
- 过度使用:在一些简单的应用中,过度使用 Eva.js 可能会导致代码冗余和不必要的复杂性。
Eva.js 是一个功能强大的状态管理库,适用于中大型的 React 项目。它通过数据驱动的开发模式和组件化的思想,提供了简洁、可维护和可扩展的解决方案。然而,对于小规模项目或者初学者来说,可能需要仔细权衡是否真正需要引入 Eva.js,以及使用的复杂性和学习成本。
五、相关链接
Eva.js文档
Evajs: Eva.js 是一款专注于开发游戏化项目的游戏引擎
eva-engine/eva.js - GitHub
Eva.js学习笔记
相关文章:
Eva.js是什么(互动小游戏开发)
前言 Eva.js 是一个专注于开发互动游戏项目的前端游戏引擎。 易用:Eva.js 提供开箱即用的游戏组件供开发人员立即使用。是的,它简单而优雅! 高性能:Eva.js 由高效的运行时和渲染管道 (Pixi.JS) 提供支持,这使得释放设…...
监听 beforeunload 事件,阻止页面刷新导致的信息丢失
尤其是一个有编辑器的页面,可以监听 windwo.beforeunload 事件,在用户试图关闭当前标签页的时候提醒用户,内容可能会丢失。 Window:beforeunload 事件 - Web API 接口参考 | MDN...
Java 常见缓存详解以及解决方案
一. 演示Mybatis 一级缓存 首先我们准备一个接口 两个实现的方法, 当我们调用这个queryAll()方法时我们需要调用selectAll()方法来查询数据 调用此接口实现效果 这个时候我们就可以发现了问题,我们调用方法…...
Golang 交叉编译之一文详解
博客原文 文章目录 Golang 中的交叉编译不同操作系统间的编译Linux 下编译windowsmacos windows 下编译Linuxmacos macos 下编译Linuxwindows 不同架构下的编译amd64x86 参考 Golang 中的交叉编译 在 Golang 中,交叉编译指的是在同一台机器上生成针对不同操作系统或…...
最新ThinkPHP版本实现证书查询系统,实现批量数据导入,自动生成电子证书
前提:朋友弄了一个培训机构,培训考试合格后,给发证书,需要一个证书查询系统。委托我给弄一个,花了几个晚上给写的证书查询系统。 实现功能: 前端按照姓名手机号码进行证书查询证书信息展示证书展示&#x…...
windows安装运行Apache James(基于spring的版本)
下载地址 下载列表 https://james.apache.org/download.cgi 直接下载基于spring版本 https://www.apache.org/dyn/closer.lua/james/server/3.8.0/james-server-app-3.8.0-app.zip 设置签名 解压,并切换到james-server-spring-app-3.8.0目录下,在powe…...
Elasticsearch 基本概念:快速入门指南【记录】
简单记录,后续整理补充 介绍: Elasticsearch是一个分布式、可扩展、实时的搜索和分析引擎,建立在开源搜索库Lucene之上。它提供了强大的全文搜索功能和复杂的分析能力,适用于各种场景,包括应用日志分析、电子商务搜索…...
【JVM 基础】类字节码详解
JVM 基础 - 类字节码详解 多语言编译为字节码在JVM运行Java字节码文件Class文件的结构属性从一个例子开始反编译字节码文件字节码文件信息常量池方法表集合类名 再看两个示例分析try-catch-finallykotlin 函数扩展的实现 源代码通过编译器编译为字节码,再通过类加载…...
【算法】基础算法001之双指针
👀樊梓慕:个人主页 🎥个人专栏:《C语言》《数据结构》《蓝桥杯试题》《LeetCode刷题笔记》《实训项目》《C》《Linux》《算法》 🌝每一个不曾起舞的日子,都是对生命的辜负 目录 前言 1.数组分块…...
[力扣 Hot100]Day2 字母异位词分组
题目描述 给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。 字母异位词 是由重新排列源单词的所有字母得到的一个新单词。 出处 思路 这题有点考阅读理解,意思就是把输入数组中的所含字母相同但顺序不同的单词放到同…...
记一次 easyswoole 热重载失效复盘 grpc扩展惹的祸
首先看一下运行环境 swoole version 4.8.11 php version 7.4.33 easyswoole version 3.4.6 在easyswoole 的入口文件 如下: <?php namespace EasySwoole\EasySwoole; use App\WebSocket\WebSocketEvents; use Ap…...
存储过程从表中获取数据库名称
---------------业务数据库信息 CREATE TABLE [dbo].[app_erp_datbabase_conf] ( [id] [int] IDENTITY(1,1) NOT NULL, [database_type] [varchar](200) NOT NULL, [database_name] [varchar](200) NOT NULL, [create_time] [datetime] NULL, [modify_t…...
.NET 反射的介绍和简单应用
什么是反射? 反射就是动态发现类型信息的能力。它帮助程序设计人员在程序运行时利用一些信息去动态地使用类型,这些信息在设计时是未知的,这种能力类似于后期绑定。反射还支持的更高级的行为,能在运行时动态创建新类型࿰…...
在drawio中使用BPMN2.0绘制详细的业务流程图和编排模型
在drawio中使用BPMN2.0绘制详细的业务流程图和编排模型 drawio是一款强大的图表绘制软件,支持在线云端版本以及windows, macOS, linux安装版。 如果想在线直接使用,则直接输入网址draw.io或者使用drawon(桌案), drawon.cn内部完整的集成了drawio的所有功…...
GO——defer函数
定义 当前函数返回之前执行传入函数的一个关键字 执行时间 当前函数返回前执行 常用于 关闭文件描述符关闭数据库链接解锁资源 原理 参考:https://draveness.me/golang/docs/part2-foundation/ch05-keyword/golang-defer/ 后调用的 defer 函数会先执行&…...
【UE Niagara学习笔记】06 - 制作火焰喷射过程中飞舞的火星
在上一篇博客(【UE Niagara学习笔记】05 - 喷射火焰顶部的蓝色火焰)的基础上继续实现喷射火焰的火星的效果。 目录 效果 步骤 一、创建材质实例 二、添加新的发射器 2.1 设置粒子材质 2.2 设置发射器持续生成粒子 2.3 设置粒子生成数量 2.4 设…...
机器学习笔记一之入门概念
目录 一 基本分类二 按模型分类概率模型(Probabilistic Models)非概率模型(Non-Probabilistic Models)对比结论线性模型 (Linear Models)非线性模型 (Non-linear Models)对比 三 按算法分类1.批量学习(Batch Learning&…...
用于脚本支持的 CSS 媒体查询
Chrome 120 于近日发布,在这个版本中,我们获得了用于脚本支持的 CSS 媒体查询。简单地说,此媒体查询允许我们测试脚本语言是否可用,并根据支持定制页面内容和样式。我是白特,让我们一起来学习下吧。 媒体查询语法 媒…...
【HBase】——整合Phoenix
1 概述 Phoenix 是 HBase 的开源 SQL 皮肤。可以使用标准 JDBC API 代替 HBase 客户端 API 来创建表,插入数据和查询 HBase 数据。 Phoenix 在 5.0 版本默认提供有两种客户端使用(瘦客户端和胖客户端),在 5.1.2 版本 安装包中…...
【操作系统xv6】学习记录5--实验1 Lab: Xv6 and Unix utilities
ref:https://pdos.csail.mit.edu/6.828/2020/xv6.html 实验:Lab: Xv6 and Unix utilities 环境搭建 实验环境搭建:https://blog.csdn.net/qq_45512097/article/details/126741793 搭建了1天,大家自求多福吧,哎。~搞环境真是折磨…...
Python爬虫实战:研究MechanicalSoup库相关技术
一、MechanicalSoup 库概述 1.1 库简介 MechanicalSoup 是一个 Python 库,专为自动化交互网站而设计。它结合了 requests 的 HTTP 请求能力和 BeautifulSoup 的 HTML 解析能力,提供了直观的 API,让我们可以像人类用户一样浏览网页、填写表单和提交请求。 1.2 主要功能特点…...
Python:操作 Excel 折叠
💖亲爱的技术爱好者们,热烈欢迎来到 Kant2048 的博客!我是 Thomas Kant,很开心能在CSDN上与你们相遇~💖 本博客的精华专栏: 【自动化测试】 【测试经验】 【人工智能】 【Python】 Python 操作 Excel 系列 读取单元格数据按行写入设置行高和列宽自动调整行高和列宽水平…...
电脑插入多块移动硬盘后经常出现卡顿和蓝屏
当电脑在插入多块移动硬盘后频繁出现卡顿和蓝屏问题时,可能涉及硬件资源冲突、驱动兼容性、供电不足或系统设置等多方面原因。以下是逐步排查和解决方案: 1. 检查电源供电问题 问题原因:多块移动硬盘同时运行可能导致USB接口供电不足&#x…...
1.3 VSCode安装与环境配置
进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件,然后打开终端,进入下载文件夹,键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...
Caliper 负载(Workload)详细解析
Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...
STM32---外部32.768K晶振(LSE)无法起振问题
晶振是否起振主要就检查两个1、晶振与MCU是否兼容;2、晶振的负载电容是否匹配 目录 一、判断晶振与MCU是否兼容 二、判断负载电容是否匹配 1. 晶振负载电容(CL)与匹配电容(CL1、CL2)的关系 2. 如何选择 CL1 和 CL…...
LOOI机器人的技术实现解析:从手势识别到边缘检测
LOOI机器人作为一款创新的AI硬件产品,通过将智能手机转变为具有情感交互能力的桌面机器人,展示了前沿AI技术与传统硬件设计的完美结合。作为AI与玩具领域的专家,我将全面解析LOOI的技术实现架构,特别是其手势识别、物体识别和环境…...
OCR MLLM Evaluation
为什么需要评测体系?——背景与矛盾 能干的事: 看清楚发票、身份证上的字(准确率>90%),速度飞快(眨眼间完成)。干不了的事: 碰到复杂表格(合并单元…...
OPENCV图形计算面积、弧长API讲解(1)
一.OPENCV图形面积、弧长计算的API介绍 之前我们已经把图形轮廓的检测、画框等功能讲解了一遍。那今天我们主要结合轮廓检测的API去计算图形的面积,这些面积可以是矩形、圆形等等。图形面积计算和弧长计算常用于车辆识别、桥梁识别等重要功能,常用的API…...
Redis专题-实战篇一-基于Session和Redis实现登录业务
GitHub项目地址:https://github.com/whltaoin/redisLearningProject_hm-dianping 基于Session实现登录业务功能提交版本码:e34399f 基于Redis实现登录业务提交版本码:60bf740 一、导入黑马点评后端项目 项目架构图 1. 前期阶段2. 后续阶段导…...
