PixiJS教程(004):点击事件交互

1.6 事件交互

实现要求:点击宝剑,修改宝剑的颜色。

1️⃣实现代码:

js 复制代码
// 为精灵添加交互事件
sprite.interactive = true;
sprite.on('click', () => {
    // 点击精灵时,改变精灵的颜色
    sprite.tint = Math.random() * 0xFFFFFF;
});

说明:

  1. 在 PixiJS 中,sprite.tint 是一个用于改变精灵(Sprite)颜色的属性。它通过乘法混合的方式将指定的颜色应用到精灵的原始纹理上,从而实现变色效果。

2️⃣实现效果:

3️⃣完整代码:

js 复制代码
<template>
<div>

</div>
</template>

<script setup>
// 导入pixi.js
import * as PIXI from 'pixi.js';
// 创建应用
const app = new PIXI.Application({
    width: window.innerWidth,
    height: window.innerHeight,
    backgroundColor: 0x1099bb,
    resolution: window.devicePixelRatio || 1,
    // 设置抗锯齿
    antialias: true
})
// 将应用画布添加到DOM中
document.body.appendChild(app.view);

// 创建一个纹理
const texture = PIXI.Texture.from('./textures/mujian.png');
// 创建一个精灵
const sprite = new PIXI.Sprite(texture);
// 设置精灵的锚点
sprite.anchor.set(0.5, 0.5);
// 设置精灵的位置
sprite.position.set(window.innerWidth / 2, window.innerHeight / 2);
// 设置精灵的缩放
sprite.scale.set(0.5, 0.5);
// 设置精灵的旋转
sprite.rotation = 0.5;
// 将精灵添加到舞台
app.stage.addChild(sprite);

// ticker实现动画
app.ticker.add((delta) => {
    // 每帧旋转精灵
    sprite.rotation += 0.01 * delta;
});

// 为精灵添加交互事件
sprite.interactive = true;
sprite.on('click', () => {
    // 点击精灵时,改变精灵的颜色
    sprite.tint = Math.random() * 0xFFFFFF;
});

</script>

<style>
*{
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}
canvas{
    width: 100vw;
    height: 100vh;
    position: fixed;
    left: 0;
    top: 0;
}
</style>
相关推荐
德育处主任2 天前
在小程序做海报的话,Painter就很给力
前端·微信小程序·canvas
熊猫钓鱼>_>5 天前
解决Web游戏Canvas内容在服务器部署时的显示问题
服务器·前端·游戏·canvas·cors·静态部署·资源路径
Lsx_7 天前
案例+图解带你一文读懂Svg、Canvas、Css、Js动画🔥🔥(4k+字)
前端·javascript·canvas
狂龙骄子7 天前
uniapp圆形时钟
小程序·uniapp·canvas·clock·圆盘时钟
若梦plus8 天前
Canvas基础
前端·canvas
若梦plus8 天前
Canvas的未来之AI绘图、生成式视觉与XR
前端·canvas
1024肥宅9 天前
综合项目实践:可视化技术核心实现与应用优化
svg·webgl·canvas
Just_Paranoid11 天前
【SystemUI】基于 Android R 实现下拉状态栏毛玻璃背景
android·canvas·systemui·renderscript
阿拉斯攀登13 天前
电子签名:SpringBoot + 汉王 ESP560 的考核签名项目实施方案
springboot·canvas·电子签名·电子签·汉王
Danny_FD16 天前
使用Taro实现微信小程序仪表盘:使用canvas实现仪表盘(有仪表盘背景,也可以用于Web等)
前端·taro·canvas