导航

萌即是正义!时不时分享一些ACG活动记录与有趣代码的小站!

侧边栏
热门文章
1页面
程序员老黄历&求签
热度
455
2推文
一开始还以为是2.5次元的舞台剧,结果仔细一看是音乐剧!?有一丢丢的兴趣,到时候看看能不能搞到门票。 《FateZero》真人音乐剧 定妆照预告:https://www.bilibili.com/video/BV1RqSoYmEzJ
热度
207
3博文
探访《蜡笔小新》老家——春日部游记
热度
104
4博文
《孤独摇滚》圣地巡礼——下北泽&下北泽咖喱节2023
热度
91
5推文
知道这套道具的人年纪应该都不小了吧。
热度
78
6推文
刚发完对《冒险岛Online》R区的遗憾没多久,韩服那边又开始搞事情了,做出了如下的修改: 1、删除持有金币,主要消耗、其他道具; 2、可使用拍卖、个人件交易、金币市场功能; 3、装备卷轴强化和可用附加潜能,但是该效果在3个月内不生效,R区的终伤BUFF仍旧保存3个月; 4、删除R区被动中BOSS装备掉率增加属性等全部属性; 5、现有装备道具均变为永久不可交易道具。 ※主要删除道具:金币、红魔方、黑魔方、痕迹、强大火花、核心宝石、可获得装备的部分消耗道具、可通过金币购买的道具等。 这可真是至R区于死地啊...要说修改游戏的模式也就算了,现在不仅没有任何补充,还把先前的劳动成果给删除了是不是太过分了!? 日服到时候肯定二话不说跟进,国际服那边如果没了韩服对R区的技术支持,个人觉得服软也是时间的问题。
热度
52
7博文
谈谈这次《冒险岛Online》日服R区的削弱事件
热度
52
8推文
发现《爱上火车》的完全版仅售280日元就果断入了!虽然Lose解散了,但是留下了巨大的财富。
热度
52
9博文
记录第一次在日本进行携号转网(MNP)
热度
52
10博文
文石BOOX Leaf2使用感想
热度
52
最新评论
广树
2024-11-21 16:04
@hikari:BGM也许是吧,歌曲部分感觉不一定
hikari
2024-11-21 09:52
居然是音乐剧!真是没想到,难道说会用梶浦大妈的配乐吗?看预告片里就用的是fz里最扣人心弦的bgm。🥰
广树
2024-11-20 08:18
@石樱灯笼:这应该是受众的年龄层的问题吧
石樱灯笼
2024-11-20 06:57
@广树:承太郎抽根烟,整张嘴都被打码。
广树
2024-11-20 06:48
@石樱灯笼:不是挺符合人设吗?为什么会离谱?
正在攻略

logo_kai.jpg


PSN奖杯卡

PSN奖杯卡

赞助商广告

2D WebGL renderer Pixi.js v4 入门【第四回】

作者:广树时间:2018-08-31 13:36:36分类:JavaScript/jQuery/Vue

前情回顾

上回链接:2D WebGL renderer Pixi.js v4 入门【第三回】

精灵制作篇完结了,在前面我们尝试制作了一些(无限)动画呢。

然后还制作了根据方向键移动的精灵。


精灵的编组

所谓编组就是制作一个新的Container(),将出现在同一场景下的东西集中起来传到renderer中。

使得精灵的管理变得更加便捷了呢!

var id = resources["images/animals.json"].textures;

// 猫
var cat = new Sprite(id["cat.png"]);
cat.position.set(16, 16);

// 刺猬
var hedgehog = new Sprite(id["hedgehog.png"]);
hedgehog.position.set(32, 32);

// 老虎
var tiger = new Sprite(id["tiger.png"]);

// 被称之为动物的类别
var animals = new Container();

// 把动物们塞进去
animals.addChild(cat);
animals.addChild(hedgehog);
animals.addChild(tiger);

stage.addChild(animals);
renderer.render(stage);

<点击查看效果>


编组的animals贴付在了左上角。

也就是说每个小图的定位都基于animals的左上角了。

animals.position.set(64, 64);

<点击查看效果>


就算调整animals的位置,其内部内容的重叠情况也不会发生改变。


编组之后,animals在canvas内的位置就犹如local和global一样的关系。


所以这里

console.log(cat.x);
> 16


出现的是最初设定animals内的数值。(也就是说这里表示的是local的数值。)

cat.position.set(16, 16);
//parentSprite.toGlobal(childSprite.position)

console.log(animals.toGlobal(cat.position));
> cat {x: 80, y: 80...}


使用父级精灵的toGlobal function的话就能知道相对于整体的绝对定位。

如果不知道父级精灵的名字,也可以如下面这样写。

console.log(cat.parent.toGlobal(cat.position));

// 也可以这么写
console.log(tiger.getGlobalPosition().x);
console.log(tiger.getGlobalPosition().y);


既然有toGlobal function,那么也就会有toLocal function。

// sprite.toLocal(sprite.position, anyOtherSprite)

console.log(tiger.toLocal(tiger.position, hedgehog).x);
console.log(tiger.toLocal(tiger.position, hedgehog).y);

上面的代码是老虎和刺猬之间的距离。

这在检测精灵距离的时候非常有用。


变更为粒子容器,使速度更上一层楼

至今为止我们一直不抱疑问去使用PIXI.Container(),其实还有一个比前者快2倍甚至5倍的Container(容器)。这就是PIXI.particles.ParticleContainer

为什么会更快,是因为设置比普通的Container更少。根据指定设置(position, scale, rotation),将使用细化从而剔除不必要的运算。

制作ParticleContainer的时候,事先通过参数和设置来指定精灵的最大数。

var sprites = new PIXI.particles.ParticleContainer(10000, {

 scale: true,

 position: true,

 rotation: true,

 uvs: true,

 alpha: true

});

这里的设置如果全部设置为flase的话速度将会更快。

<点击查看效果>


这次对于精灵的编组进行了各种研究,在下回我们将说一下和精灵没有太大关系的东西,所以就先到这里。


我们下回见


本文翻译自:2D WebGL renderer Pixi.js v4【連載第四回】
翻译者:广树
转载请注明出处!


2D WebGL renderer Pixi.js v4 入门【第五回】

#pixi.js

donate.png

1210 x 50(蓝底).png

cloudcone