导航

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

侧边栏
热门文章
1博文
《摇曳露营△》十周年纪念展
热度
349
2页面
程序员老黄历&求签
热度
260
3推文
作为凉宫春日等人就读的“北高”的原型,其校园风景在动画中得以重现的兵库县立西宫北高等学校,将在2027年3月末以“西宫北高校”的名义关闭,并由“西宫苦乐园高校”接管。 一直以来,许多粉丝都将西宫北高作为凉宫春日的“圣地”来访问。虽然该校此前从未对外开放校内,但这次将首次举办校内公开企划! 在这次活动中,大家可以欣赏动画中出现的场景,并在校园内进行拍照留念等活动。 ※ 截至2025年11月14日,入场门票已全部售罄,且不会追加销售。请注意,未持有入场门票者将无法进入会场。
热度
104
4博文
探访日本的废校 《轻音少女》圣地巡礼之丰乡小学校旧校舍群
热度
65
5页面
阅读
热度
65
6页面
友链
热度
65
7页面
追番
热度
52
8推文
昨晚的国际互联网经历了一场灾难。 维基萌也被波及到了呢!由于设置了站点检测,昨晚故障警报不停。 一开始还以为维基萌服务器又出问题了,结果一看居然是 Cloudflare ? 看起来是由于 CDN 运营商 Cloudflare 的故障。众多网络服务出现了无法访问的情况。 更要命的是,面板也同时出现故障导致无法临时切换解析地址。 就这样故障从日本时间将近晚上9点,一直持续到了晚上11点过后,维基萌的访问才安定下来。 事后看来是由于不正确的配置导致的此次灾难。具体可以看官方的报告。 https://blog.cloudflare.com/18-november-2025-outage/ 不得不说今年由于大厂的失误导致的互联网服务灾难是不是太多了一点?
热度
39
9推文
えなるる~
热度
39
10页面
足迹
热度
39
最新评论
广树管理员
2025-11-21 19:57
@石樱灯笼:那就少子老龄化吧
石樱灯笼
2025-11-21 13:13
@广树:这玩意叫少子化,不叫老龄化。
广树管理员
2025-11-20 22:03
虽然不是真正意义上的闭校。但是作为作品中的那所学校因为少子老龄化最后并校与更名,还是有些可惜的。 很想去,但是似乎知道的有些太迟了呢。
广树管理员
2025-11-20 11:26
@小彦:淡定,日本民众根本不关心这些
广树管理员
2025-11-20 11:26
@老张博客:是呀
攻略中
全民高尔夫环球之旅
暂无评分
Steam全民高尔夫环球之旅
2025年9月07日 12时 ~ 攻略中
已累计游玩2个月16天
《全民高尔夫 环球之旅》除了能体验到与过去作品相同的乐趣、爽快与深奥之外, 还有着以精美图像设计而成、个性丰富的角色们与以世界各地为主题的球场, 以及能让所有人热血沸腾的全新模式等等,是本系列的全新力作!
ToHeart
暂无评分
SteamToHeart
2025年6月26日 19时 ~ 攻略中
已累计游玩4个月28天
AQUAPLUS推出的“温暖人心的校园恋爱游戏”将以高清全3D形式焕新归来!
fault - StP - LIGHTKRAVTE
暂无评分
Steamfault - StP - LIGHTKRAVTE
2025年5月29日 20时 ~ 攻略中
已累计游玩5个月26天
全球累计销量超过50万份的“fault”系列最新作!故事的舞台是一个融合了奇幻与科幻的超前世界——卢森海德王国。本作讲述了生活在此地的一个平凡又平庸的究极普通市民——名为果子的少年的故事。
PSN奖杯卡

PSN奖杯卡

归档
赞助商广告

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

作者:广树时间:2018-08-31 15:08:01分类:JavaScript

前情回顾

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

上回我们说了精灵的编组以及Container和ParticleContainer。

这次我们来说说WebGL的图形绘制吧。


图形绘制的方法

如果懂canvas自带的图形绘制功能的话,大可跳过这里。

首先使用PIXI.Graphics,描绘各种图形。

// 画矩形
var rectangle = new Graphics();

// lineStyle(width, color , alpha透明度)
rectangle.lineStyle(4, 0xFF3300, 1);

rectangle.beginFill(0x66CCFF);

// drawRect(x, y, width, height)
rectangle.drawRect(0, 0, 64, 64);

rectangle.endFill();

// 位置(基于矩形左上角)
rectangle.x = 170;
rectangle.y = 170;
stage.addChild(rectangle);

// 画圆
var circle = new Graphics();
circle.beginFill(0x9966FF);

// drawCircle(x, y, radius半径)
circle.drawCircle(0, 0, 32);
circle.endFill();

// 位置(基于圆的中心)
circle.x = 64;
circle.y = 130;
stage.addChild(circle);

// 画椭圆
var ellipse = new Graphics();
ellipse.beginFill(0xFFFF00);

// drawEllipse(x, y, width, height);
ellipse.drawEllipse(0, 0, 60, 20);
ellipse.endFill();

// 位置(基于中心点)
ellipse.x = 180;
ellipse.y = 130;
stage.addChild(ellipse);

// 画圆角矩形
var roundBox = new Graphics();
roundBox.lineStyle(4, 0x99CCFF, 1);
roundBox.beginFill(0xFF9933);

// drawRoundedRect(x, y, width, height, cornerRadius)
roundBox.drawRoundedRect(0, 0, 84, 36, 10)
roundBox.endFill();

// 位置(基于矩形左上角)
roundBox.x = 48;
roundBox.y = 190;
stage.addChild(roundBox);

// 画直线
var line = new Graphics();
line.lineStyle(4, 0xFFFFFF, 1);

// 开始
line.moveTo(0, 0);
// 结束
line.lineTo(80, 50);

// 位置
line.x = 32;
line.y = 32;
stage.addChild(line);

// 画三角形
var triangle = new Graphics();
triangle.beginFill(0x66FF33);

triangle.drawPolygon([
    -32, 64,             //最初的坐标点
    32, 64,              //第二个坐标点
    0, 0                 //第三个坐标点
    
]);

triangle.endFill();

// 位置(基于最初的坐标点)
triangle.x = 180;
triangle.y = 22;

stage.addChild(triangle);

完成效果如下,和canvas并没有多大区别。

<点击查看效果>


文字

使用PIXI.Text function。绘制方法和canvas也类似。

var message = new Text(
  "Hello Pixi!",
  {fontFamily: "Arial", fontSize: 32, fill: "white"}
);

message.position.set(54, 96);
stage.addChild(message);


中途可以再次定义样式和文本。

message.text = "Text changed!";
message.style = {font: "16px PetMe64", fill: "pink"};


在canvas的时候比较困扰的文字换行部分,这里也可以用样式来指定。

message.style = {wordWrap: true, wordWrapWidth: 5, align: "left"};



这里有一个注意点。

在英语的情况下,无法拆分单个单词(手写或者用word的时候,换行普遍会使用‘-’,但是这里不行)。

单词会在结束之前全部输出。具体可以看下面的例子。

<点击查看效果>


反过来说,中文的情况下,不会使用半角空格去拆分单词,所以要换行的话就不得不使用半角空格。


PS1 如果中途要改变style的话会覆盖上面的设定,所以要重新定义fill。


PS2 pixi.js可以使用BitmapText,但是深入研究后发型并不简单,非常抱歉,这里先掠过。

这里姑且先放上pixi.js官方文档。

Class: BitmapText


下回将会有涉及到游戏相关的东西!

敬请期待。


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


2D WebGL renderer Pixi.js v4 入门【最终回】

donate.png


telegram banner (1).png


1210 x 50(蓝底).png

cloudcone