PIXIJS快速一览

简介: PIXIJS快速一览前言还记得我们最开始选择计算机专业的时候,是多少人抱着做一个游戏的初心选择这个专业的。结果一进去就跟随大众方向做了软件开发,然后就没然后了。所以,最近稍微空闲下来了,就想着自己做一个小游戏出来玩玩或者说练练手。自己作为前端开发,所以就没必要单独学习Unity或者说虚幻引擎这类的工具了。就直接找个webGL相关的游戏引擎来用用吧

PIXIJS快速一览

前言


还记得我们最开始选择计算机专业的时候,是多少人抱着做一个游戏的初心选择这个专业的。结果一进去就跟随大众方向做了软件开发,然后就没然后了。

所以,最近稍微空闲下来了,就想着自己做一个小游戏出来玩玩或者说练练手。自己作为前端开发,所以就没必要单独学习Unity或者说虚幻引擎这类的工具了。就直接找个webGL相关的游戏引擎来用用吧,然后我就发现了PIXIJS,感觉不错,我们一起来学学它。

作为前端,学了它不仅可以做一个小游戏,以后做一些有意思的动画效果也可以用到它,可谓是一举多得,该学!

注:本文为PIXI入门教程,不会深入

是什么


官网原文:PixiJS 是什么

笔者感觉的主要特点就是:

  1. 轻量
  2. 开源

软件开发中一个非常重要的思想就是“小而美 ”,当然原话笔者忘了,这是现在笔者想到的最符合这个意思的一句话。

有所为,有所不为,即找准边界

就好比UNIX的文件系统的设计理念:

每个Unix文件都只是一系列字节的组合。文件内容的结构或组织方式只由处理它的程序决定,文件系统本身并不关心文件中的内容。这意味着任何程序都可以读取或写入任何文件。

每个Unix文件都只是一系列字节的组合。文件内容的结构或组织方式只由处理它的程序决定,文件系统本身并不关心文件中的内容。这意味着任何程序都可以读取或写入任何文件。

回到这里,PIXI就只是一个渲染引擎,它既不是一个框架,也不是一个游戏动画库、音频库,就好比官网中说到:

如果您正在为您的下一个基于 Web 的项目寻找一个专注、快速和高效的渲染引擎,PixiJS 可能是一个非常合适的选择。

如果您需要一个完整的游戏开发框架,具有原生绑定和丰富的 UI 库,您可能需要探索其他选项。

那如何理解渲染引擎这个关键词呢?简单来说:就是负责将代码中描述的图像和动画内容呈现在屏幕上的工具。

最小的一个例子



<!doctype html>
<html>
  <head>
    <script src="https://pixijs.download/release/pixi.min.js"></script>
  </head>
  <body>
    <script>
      // 创建应用并插入DOM
      let app = new PIXI.Application({ width: 640, height: 360 });
      document.body.appendChild(app.view);
      // 创建图像对象并放入应用中
      let sprite = PIXI.Sprite.from('sample.png');
      app.stage.addChild(sprite);
      app.ticker.add((delta) => {
    // 动画处理,比如平移
      });
    </script>
  </body>
</html>


好,到现在你应该记住一个基本的PIXI例子应该有:

容器(Container)


当舞台中跳舞的人多了之后,分队(分组)就显得很有必要了。Container就是扮演这样一个角色。有了它,舞台中就形成了类似于DOM树的结构了,app.stage作为根节点。

几乎每种类型的显示对象也都派生自 Container

比如上述中的sprite也继承于它,但为什么不用sprite来分组呢?想想sprite还实现了许多特定领域的方法和属性,虽然也可以作为container来使用,但是不是成了炮弹打蚊子了呢?浪费!

除分组功能之外,container还有以下两个常见作用:

  • 遮罩:PS里面的蒙版,前端里面的overflow: hidden;值得注意的是,那些继承于container的对象肯定也有这个属性(功能),比如Graphics创建几何图形作为几何遮罩等等;
  • 滤镜:比如模糊效果,通过在容器上设置过滤器,容器包含的屏幕区域都会有这个滤镜效果。

纹理(Textures)


简单来说就是某片屏幕区域的像素源,比如常见的就是加载一个图像作为该屏幕的像素源。

加载过程:Source Image > Loader > BaseTexture > Texture

解释一下几个关键词:

Loader:提供了用于异步加载图像和音频文件等资源的工具,而后面两个听名字你应该就知道是啥关系了:

  • BaseTexture是一个低级别的纹理数据源,它定义了一个纹理的加载和处理方式,并提供了一些用于控制纹理属性、缓存处理、加载管理和镜像等操作的方法。BaseTexture实例通常包含一张或多张纹理图像的数据信息,这些图像可以是来自于网络的URL,也可以是Canvas画布或者图片资源等。
  • Texture则是BaseTexture的高级封装,它包含一个或多个用于渲染的纹理,同时也具有基于BaseTexture的镜像、缩放、平移等变换操作。Texture类提供了许多有用的方法和属性,比如调整纹理的尺寸、获取纹理的UV贴图、设置填充模式等等。
const baseTexture = PIXI.BaseTexture.from("./textures/game.png");
const texture = new PIXI.Texture(
  baseTexture,
  new PIXI.Rectangle(75, 0, 88, 100)
);
const sprite = new PIXI.Sprite(Texture);


注意:不常用的纹理记得手动卸载destory()

图形(Graphics)


就是创建所谓直线、矩形、圆形、贝塞尔曲线能你能想到的图形;

// 1. 先创建结构
let obj = new PIXI.Graphics();
obj.beginFill(0xff0000);
obj.drawRect(0, 0, 200, 100);
// 2. 后添加
app.stage.addChild(obj);


image.png你可以在这里找到绘制这些图形的代码

同样需要注意卸载destory(),PIXI并不会自动回收。

互动


DisplayObject是引擎可以呈现的任何内容的核心类。它是精灵、文本、复杂图形、容器等的基类,并为这些对象提供许多通用功能。如移动、缩放、旋转和组合等

任何DisplayObject派生对象(SpriteContainer 等)都可以通过将其interactive属性设置为true来实现交互,比如对某个图片监听点击事件:

let sprite = PIXI.Sprite.from('/some/texture.png'); sprite.on('pointerdown', (event) => { alert('clicked!'); });


默认情况下,PixiJS 使用交互式对象的边界矩形来确定鼠标或触摸事件是否“点击”了该对象。有时候,比如我们需要对一个复杂的图形创建点击区域,并只想记录该形状内的点击,就需要DisplayObject的hitArea属性

除此之外,你还可以通过hitTest在某一区域寻找可交互对象,用来做碰撞检测比较合适:


let globalPt = new PIXI.Point(100,50);
let obj = app.renderer.plugins.interaction.hitTest(globalPt);


注意:前端中有事件捕获和事件冒泡等阶段,而这里也是树结构,所以如果您的容器或其他对象具有您知道永远不会交互的复杂子树,则可以将interactiveChildren属性设置为false,命中测试算法将在检查悬停和单击事件时跳过这些子树。

文本(Text)


没啥说的,就创建文本对象,然后文本对象有一些常见的样式属性,这对于前端程序员来说一点也不陌生。

官网中提到有一些注意的地方:

首先,更改现有文本字符串需要重新生成该文本的内部渲染,这是一个缓慢的操作,如果您每帧更改许多文本对象,可能会影响性能。如果您的项目需要同时在屏幕上显示大量经常更改的文本,请考虑使用 PIXI.BitmapText 对象,该对象使用固定的位图字体,当文本更改时不需要重新生成。

其次,缩放文本时要小心。将文本对象的比例设置为 > 1.0 将导致模糊/像素显示,因为文本不会以看起来清晰所需的更高分辨率重新呈现 - 它仍然与生成时的分辨率相同。为了解决这个问题,您可以改为以更高的初始尺寸和缩小比例进行渲染。这将使用更多内存,但会让您的文本始终看起来清晰明快。

最后


本文主要叙述了PIXI作为渲染引擎包含三种基本的要素:

  1. 场景,根节点就是app.stage
  2. 里面的对象,如ContainerSpriteGraphicsText等等
  3. 时间线Ticker,每一帧该做什么

本文没有讲述例子,但程序员的学习肯定少不了实践,官网这里有非常多了入门教程示例

好,没了,休息休息~

笔者目前也是作为PIXI的新手,如果上述中有一些理解不到位或者说错误的地方,欢迎友善指出



目录
相关文章
|
8月前
|
小程序 前端开发 物联网
【经验分享】如何实现快速生成生活圈海报分享图
【经验分享】如何实现快速生成生活圈海报分享图
121 4
|
设计模式 Dubbo NoSQL
6年Java经验,4面阿里定级P7,多亏阿里13万字+脑图+源码面试笔记
互联网公司的面试,从形式上说,一般分为 2~3轮技术面 +1 轮 HR 面,不过某些公司没有 HR 面试。 在技术面试中,面试官一般会就你所应聘的岗位进行相关知识的考察,也叫基础知识和业务逻辑面试,只要回答的不是特别差,面试官通常会继续跟你聊聊项目,这个时候就开始了项目面试。
|
设计模式 算法 程序员
一张截图,告诉你字节跳动的《设计模式宝典》到底有多强
格局小了,算法像是单兵的作战能力和武器装备,设计模式像打仗列的阵型。只是单挑的话, 阵型就不重要了(叫单例模式也可以吧);如果是群斗,请参考戚家军是如何用鸳鸯阵吊打单兵作战能力爆表的日本武士;
|
开发框架 Java Spring
高光时刻!美团推出Spring源码进阶宝典:脑图+视频+文档
Spring是一个开源框架,相信很多做Java开发的技术人员对Spring并不陌生,Spring是现在企业中经常会用到的,是为了解决企业应用程序开发复杂性而创建的。Spring主要的优势就是可以分层架构,可以为你提供选择使用哪一个组件,同时也会为J2EE应用程序开发体提供集成的框架!
78 0
|
前端开发 Java
CRUP(课时十七)
CRUP(课时十七)
74 0
|
算法 定位技术
文章一览
以跑步为例,我原本只是慢慢悠悠的随性跑,一旦它成为了一个习惯,我便开始尝试着寻找其中的方法,每天早上跑半个小时左右,怎么跑才能达到更好的效果呢?那就快慢交替跑吧!同样的时间,同样的精力投入,快慢交替跑要比普通慢跑消耗更多的热量,更能提升心肺机能。
79 0
|
人工智能 Kubernetes Cloud Native
|
人工智能 达摩院 架构师
开发者社区精选直播合集一览
本合集囊括了:AI、架构师、 Serverless 、AIoT、DevOps、容器化、机器学习、云计算、K8s、微服务、云原生、视觉AI、大数据、小程序、物联网等各种主题直播合集,让你一次看个够!
4559 0
开发者社区精选直播合集一览
|
Dubbo Cloud Native 应用服务中间件
2019 历届 Dubbo Meetup 回顾合集(附 PPT 下载和视频回看)
本文整理了 Dubbo 过往活动的直播回放链接和 PPT,希望对您在使用 Dubbo 时有所帮助。
2019 历届 Dubbo Meetup 回顾合集(附 PPT 下载和视频回看)
|
Dubbo 应用服务中间件
大合集 | 10 场 Dubbo Meetup 回顾视频和PPT下载
2018年2月16日,Dubbo 加入 Apache 基金会孵化器,在随后的那个夏天,我们开始在全国(北京、上海、深圳、成都、杭州)和社区的用户们见面、认识、交个朋友,将社区的最新动态、Dubbo 的发展规划、和一些用户的最佳实践进行分享,目的是让大家在使用和共建 Dubbo 的过程中,更有参与感。
2388 0