准备
所有渲染相关的操作依赖渲染器,该渲染器是以系统的形式提供出来的,所以我们需要在初始化游戏的时候将渲染器安装到游戏上。目前 Eva.js 提供了一个 2D 的渲染器,在使用渲染相关组件的时候需要提前安装。
安装
使用 NPM
npm i @eva/plugin-renderer
在浏览器中
<!-- import PixiJS -->
<script src="//unpkg.com/pixi.js@4.8.9/dist/pixi.min.js"></script>
<!-- import RendererAdapter -->
<script src="//unpkg.com/@eva/renderer-adapter@1.2.x/dist/EVA.rendererAdapter.min.js"></script>
<script src="https://unpkg.com/@eva/plugin-renderer@1.2.x/dist/EVA.plugin.renderer.min.js"></script>
使用
import { Game, GameObject } from '@eva/eva.js'
import { RendererSystem, RENDERER_TYPE } from '@eva/plugin-renderer'
new Game({
systems: [
new RendererSystem({
canvas: document.querySelector('#canvas'), //可选,自动生成canvas 挂载game.canvas上
width: 750, //必填
height: 1000, // 必填
transparent: false, // 可选
resolution: window.devicePixelRatio / 2, // 可选, 如果是2倍图设计 可以除以 2
enableScroll: true, // 允许页面滚动
renderType: RENDERER_TYPE.UNKNOWN, // RENDERER_TYPE.UNKNOWN:自动判断,RENDERER_TYPE.WEBGL/RENDERER_TYPE.CANVAS,建议android6.1以下使用Canvas。
backgroundColor: 0xff0000
})
]
})
参数
canvas
渲染所需 canvas
width
渲染画布的宽度,设计稿的宽度,
height
渲染画布的高度,设计稿的高度
transparent
背景是否透明,默认 false
resolution
分辨率,如果设计稿是 2 倍(750*1334),可用 window.devicePixelRatio / 2
enableScroll
是否允许页面滚动,默认 true
renderType
使用 WebGL 或 Canvas 渲染默认为自动判断是否支持 WebGL
backgroundColor
背景颜色
Method
resize(width: number, height: number)
重新设置游戏渲染画布的尺寸。