当前位置: 首页 > news >正文

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

1.6 事件交互

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

1️⃣实现代码:

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

说明:

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

2️⃣实现效果:

屏幕录制-2025-07-03-115828

3️⃣完整代码:

<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>
http://www.lryc.cn/news/580052.html

相关文章:

  • gic 中断触发类型
  • Python 中线程和进程在实际项目使用中的区别和联系
  • FastAPI 小白教程:从入门级到实战(源码教程)
  • 基于Docker构建OrangePi5 SDK环境
  • 使用mindie:2.0.RC2-800I-A2-py311-openeuler24.03-lts制作一个通用的模型推理性能测试的镜像
  • Windows 10/11 PC平台关闭禁用系统自动上传相关隐私数据手册
  • TDengine STMT2 API 使用指南
  • HarmonyOS-ArkUI 手势系列4--多层级手势
  • Spring Boot 中常用的工具类库及其使用示例(完整版)
  • 洛谷P1941 [NOIP 2014 提高组] 飞扬的小鸟
  • 行阶梯形矩阵和行最简形矩阵的区别
  • 【WRFDA教程第十期】混合数据同化(Hybrid Data Assimilation)
  • 【C++复习1】基础篇
  • 负载均衡--常见负载均衡算法
  • 大带宽服务器中冗余技术的功能
  • 【深度解析】Seedance 1.0:重新定义 AI 视频生成的工业级标准
  • 10.双端Diff算法
  • [代码学习] c++ 通过H矩阵快速生成图像对应的mask
  • 嵌入式C语言:指针
  • Jenkins-Email Extension 插件插件
  • ubuntu 18.04配置镜像源
  • ubuntu22桌面版中文输入法 fcitx5
  • 运维打铁:企业云服务解决方案
  • 金融系统中常用的FIX协议
  • 企业电商解决方案哪家好?ZKmall模块商城全渠道支持 + 定制化服务更省心
  • 文本分词 nltk
  • ODS 系统是什么?企业为什么需要搭建 ODS?
  • CentOS配置网络
  • 【Oracle APEX开发小技巧15】多级弹窗关闭子级保留父级
  • 建议大家都去频繁大量地记录自己:让目标在笔尖下生根发芽