导航

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

侧边栏
热门文章
1页面
程序员老黄历&求签
热度
1131
2推文
让AI生成了头像的表情包,都好可爱呀!
热度
117
3推文
用几乎纯 AI 写维基萌公会联盟这款游戏也有段时间了,可以分享一些 AI 写项目的心得了。 先说结果,现阶段面向个人的几大 AI 模型用来开发个人小项目,实现个人的一些想法是够用的。但是用在商业项目还有待商榷。 目前用下来的问题包括但不仅限于: · 不会总结需求功能中哪些函数或者组件应该共通化,同样的功能写的到处都是。 · 由于上面的问题,修改BUG的时候经常只会改一处就觉得自己解决问题了。 · AI 有时候倾向掩盖问题而不是解决问题。比如有几次指挥解决日志中的错误,结果 AI 选择遇到此类问题不输出日志。 · 受到上下文最大输入限制,现在的 AI 是以总结交接的形式将前面的信息传递到下一任 AI ,这就导致了一旦发生交接,这段代码质量会急剧下降。 · 不约束代码习惯的时候,AI 更倾向写可读性很差的语法糖。 · UI交互设计不加详细描述就会写的一团糟。 · 游戏玩法设计幻觉严重。 当然优点也有很多。最大的优点就是减少了我自己的心智负担。并且用自己的描述成功让 AI 完美实现时的成功感。我现在算是明白为什么那么多人喜欢玩抽卡游戏了。
热度
117
4博文
360度带你看《超时空辉夜姬》联动KTV联动房间
热度
91
5博文
3DS模拟器简体中文字库 | Citra3ds字库 | 符文工房4乱码解决字库 | shared_font.bin
热度
91
6博文
大开眼界的《憧憬成为魔法少女非常热闹哟大感谢祭》S场
热度
78
7博文
《孤独摇滚》圣地巡礼——下北泽&下北泽咖喱节2023
热度
52
8页面
友链
热度
52
9推文
让AI生成了一个记账网页应用。 完全按照我自己的需求定制的记账应用。当然也有一定的通用性。 支持响应式布局,所以手机也能用。 本人只贡献了需求和修改了一丢丢UI体验。 成品还是很满意的,看来AI时代,小工具根本不需要下什么APP了。 直接自己定制应用的好时代来了呀! 项目地址:https://github.com/eeg1412/wikimoeBookkeeping ※截图是测试数据,不是我发财了。
热度
39
10博文
《爱上火车》与《铁路浪漫谭》的圣地巡礼之人吉
热度
39
最新评论
广树管理员
2026-04-16 19:18
@Asuna:几乎是的
广树管理员
2026-04-16 19:18
@ZeroCounter:让AI实现过一版,但是修改内容比预想的多太多了,根本没时间审查😅
广树管理员
2026-04-16 19:17
@Zrzzz:说不定有了呢
Asuna
2026-04-16 06:31
佬用的是 Opus 嘛,Claude 神力!😭
ZeroCounter
2026-04-15 12:40
好可爱!建议实装到评论区(什么
攻略中
告别回忆 双想 ~Not always true~
暂无评分
Steam告别回忆 双想 ~Not always true~
2026年3月10日 22时 ~ 攻略中
已累计游玩1个月7天
“我觅见了生命中的唯一,而后——”
亚路塔:狐狸狐途的面包冒险
暂无评分
Steam亚路塔:狐狸狐途的面包冒险
2026年2月12日 19时 ~ 攻略中
已累计游玩2个月3天
一场席卷全世界的面包革命现在开始! 主人公查雅阴错阳差之下,开始了在荒废的岛屿上经营面包店的生活。 出外冒险搜集食材、研发崭新面包配方、遇见性格各异的伙伴们,建造更丰富的设施,用面包香气使无人问津的广场再次热闹起来!
ToHeart
暂无评分
SteamToHeart
2025年6月26日 19时 ~ 攻略中
已累计游玩9个月24天
AQUAPLUS推出的“温暖人心的校园恋爱游戏”将以高清全3D形式焕新归来!
fault - StP - LIGHTKRAVTE
暂无评分
Steamfault - StP - LIGHTKRAVTE
2025年5月29日 20时 ~ 攻略中
已累计游玩10个月22天
全球累计销量超过50万份的“fault”系列最新作!故事的舞台是一个融合了奇幻与科幻的超前世界——卢森海德王国。本作讲述了生活在此地的一个平凡又平庸的究极普通市民——名为果子的少年的故事。
PSN奖杯卡

PSN奖杯卡

归档
赞助商广告

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

作者:广树时间:2018-08-31 10:25:05分类:JavaScript

Start with pixi.js

首先先引入pixi.js吧!

但是由于这是个练习,所以想快一点就直接读了CDN。


制作html。

<!DOCTYPE html>
<html lang="ja">
<head>
   <meta charset="UTF-8">
   <title>Start with pixi.js</title>
</head>
<body>
<script src="https://cdnjs.cloudflare.com/ajax/libs/pixi.js/4.4.3/pixi.min.js"></script>
<script type="text/javascript">
    var type = "WebGL";
    if(!PIXI.utils.isWebGLSupported()){
      type = "canvas"
    }
    PIXI.utils.sayHello(type);
</script>
</body>
</html>

由于body中没有放其他元素,所以和预想一样本地打开的时候什么都没有。

那么打开console看看吧。

QQ截图20180808221017.png

这是pixi.js读取的证据呢。

细读了代码,发现如果是不支持WebGL的话,会切换成Canvas。

QQ截图20180808221025.png

然后在控制台输出这段信息是sayHello function的机能。

因为这次用的浏览器是支持WebGL的Chrome,所以type是WebGL。


试着做点什么吧

将以下代码加到先前script的sayHello function后面。

(加入注释说明)

//生成一个新的渲染器
var renderer = PIXI.autoDetectRenderer(256, 256);

//将其插入到HTML中
document.body.appendChild(renderer.view);

//生成名为stage的容器(object)
var stage = new PIXI.Container();

//在渲染器中传入stage。
renderer.render(stage);

这似乎就是最基本的代码了。

打开浏览器会发现出现一个黑色的方块。

通过审查元素查看内容。

<canvas width="256" height="256" style="touch-action: none; cursor: inherit;"></canvas>

确认生成了canvas。


说明下autoDetectRenderer function的参数。

autoDetectRenderer(width, height, {options});


其实就是对canvas进行各种设定。

比如下面的代码

var renderer = PIXI.autoDetectRenderer(
  256, 256,
  {antialias: false, transparent: false, resolution: 1}
);


  • antialias 轮廓是否平滑?
  • transparent 是否透明?
  • resolution 倍率为1,如果输入0.5则生成尺寸减半变为128*128。


因为只是配置,加不加都无所谓。

默认配置如上面一样{antialias: false, transparent: false, resolution: 1}


强制生成WebGL或者canvas

autoDetectRenderer function会自动判断是否支持WebGL(优先WebGL),

但是如果想在不支持WebGL的浏览器中直接不运行的话就使用 WebGLRenderer function

renderer = new PIXI.WebGLRenderer(256, 256);

反之只想使用canvas的话则使用CanvasRenderer function

renderer = new PIXI.CanvasRenderer(256, 256);


有关style

renderer.backgroundColor = 0x061639;
renderer.view.style.border = "1px dashed black";

通过javascript设定样式的话

<canvas width="256" height="256" style="touch-action: none; border: 1px dashed black; cursor: inherit;"></canvas>

就会生成上面那样的canvas。


然后在中途也可以进行重置大小。

renderer.autoResize = true;
renderer.resize(512, 512);

也可以填充满整个浏览器。

renderer.view.style.position = "absolute";
renderer.view.style.display = "block";
renderer.autoResize = true;
renderer.resize(window.innerWidth, window.innerHeight);


什么是精灵

// 生成一个新的渲染器
var renderer = PIXI.autoDetectRenderer(256, 256);

// 将其插入到HTML中
document.body.appendChild(renderer.view);

// 生成名为stage的容器(object)
var stage = new PIXI.Container();

// 在渲染器中传入stage。
renderer.render(stage);

这里说下第三段(上面例子中的第8行)代码。

如container(object)的意思一样,就是容器。

可以放入许多元素的容器。

renderer.render(stage);

将其传入最上面的renderer,反映到canvas中去。

这里stage这个名字只是单纯的例子,一般情况下是会取scene或者root之类的名字。


那么,这个容器里要放入什么东西呢?那就是“精灵”了。

所谓精灵就是可控的图形(images object)。

可以控制其位置、大小、交互、动画的展示等等。


制作精灵的三种方法

1.使用图像(一个一个读取进去)

2.将项目内用到的所有图片(sub-image)全部集合成一张大图片(tileset)使用。(就是将大量小图合成一张大图)

3.通过JSON(texture atlas)指定大图(tileset)中各自图像的位置和大小。


实践篇


注意点:接下来的html为了防止本地打开后无法运行某些机能,是在设立了一个简单的服务器基础上执行的。


1.使用图像并显示出来吧(一个一个读取) 前篇

使用TextureCache function,保存图像的路径。然后建立新的精灵。


var texture = PIXI.utils.TextureCache["images/anySpriteImage.png"];
var sprite = new PIXI.Sprite(texture);

这里的"images/anySpriteImage.png"为实际要使用到的路径与图片文件名。

但是有可能会指定了路径但是并未读取,所以这里要用到loader

PIXI.loader
  .add("images/anyImage.png")
  .load(setup);

function setup() {
  //读取图片后执行
}

pixi.js开发团队推荐的使用方法:如果要使用loader的话,务必将loader读取的东西作为精灵去使用。

var sprite = new PIXI.Sprite(
  PIXI.loader.resources["images/anyImage.png"].texture
);

然后合并代码就如下面所示。

PIXI.loader
  .add("images/anyImage.png")
  .load(setup);

function setup() {
  var sprite = new PIXI.Sprite(
    PIXI.loader.resources["images/anyImage.png"].texture
  );
}

结果就像下图那样

下载.png

图片完全贴合在了左上角


补充:

如果想要追加要读取的图片,只用追加loader.add()即可。

PIXI.loader
  .add("images/imageOne.png")
  .add("images/imageTwo.png")
  .add("images/imageThree.png")
  .load(setup);

为了更加简洁集合成loader.add([])

PIXI.loader
  .add([
    "images/imageOne.png",
    "images/imageTwo.png",
    "images/imageThree.png"
  ])
  .load(setup);


变换成别的名字吧(Aliases)

刚才的代码整理起来如下。

<script>
var stage = new PIXI.Container(),
    renderer = PIXI.autoDetectRenderer(256, 256);
document.body.appendChild(renderer.view);

PIXI.loader
  .add("images/cat.png")
  .load(setup);

function setup() {
  var cat = new PIXI.Sprite(PIXI.loader.resources["images/cat.png"].texture);
  stage.addChild(cat);  
  renderer.render(stage);
}
</script>

将里面的PIXI.***全部拿出来,取一个自己看得懂的别名。

var Container = PIXI.Container,
    autoDetectRenderer = PIXI.autoDetectRenderer,
    loader = PIXI.loader,
    resources = PIXI.loader.resources,
    Sprite = PIXI.Sprite;

var stage = new Container(),
    renderer = autoDetectRenderer(256, 256);
document.body.appendChild(renderer.view);

loader
  .add("images/cat.png")
  .load(setup);

function setup() {
  var cat = new Sprite(resources["images/cat.png"].texture);
  stage.addChild(cat);
  renderer.render(stage);
}

然后将代码换成上面那样子。简洁易懂。


第一回先到此。


本回demo:点击进入

本回的代码:进入git


本文翻译自:2D WebGL renderer Pixi.js v4【連載第一回】

翻译者:广树

转载请注明出处!


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

donate.png


telegram banner (1).png