[pixi.js] 入门简单案例 简易时钟

老实说pixi虽然之前拿来做个几个简单的游戏,但是是好久前的了,又忘了,现在算是重新入门。
官网版本已经更新到v8去了,而react相关的pixi库pixi-react 虽然支持react18 但还是v6-v7的版本,既然已经看了v8的文档,那就没必要等pixi-react了,直接照着pixi文档撸吧。

先拉个react的vite脚手架下来(vue react都无所谓,基本上用不到框架或者库的api),在我的理解里,pixi每时每刻都是在内部进行不停的渲染绘制,所以跟react的render无关,同样也不需要vue的响应式视图。基本上如果更改了pixi元素的属性,下一帧就给你绘制出来了。

步入正题

安装pixi.js

pnpm add pixi.js

顺便装个gsap动画库吧

pnpm add gsap

按照官网文档初始化pixi

import { Application, Renderer, Graphics, Container, Point } from "pixi.js";
...
const ctx = useRef<HTMLDivElement | null>(null);

async function init() {
	const app = new Application();
	await app.init({
		background: '#fff',
		width: 400,
		height: 400,
	});
	return Promise.resolve(app);
}

useEffect(() => {
	init().then((app) => {
		// 把pixi挂载到页面上
		ctx.current?.appendChild(app.canvas);
	});
}, [])

return (<div className={clock.container} ref={ctx}></div>)

接下来开始绘制时钟的基本轮廓

function drwaClock(app: Application<Renderer>) {
    const clock = new Container();
    // 秒钟
    const secondContainer = new Container();
    // 分钟
    const minter = new Container();
    // 小时
    const hours = new Container();

    clock.addChild(hours);
    clock.addChild(minter);
    clock.addChild(secondContainer);
    const circle = new Graphics();
    circle
      .circle(app.screen.width / 2, app.screen.height / 2, 100)
      .fill("#33333350")
      .stroke({ width: 10, color: "#FFD5AE" });
    clock.addChild(circle);
    const second = new Graphics().rect(0, 0, 3, 100).fill("#000");
    secondContainer.addChild(second);
    // 设置矩形的旋转点为其宽度中心点和高度的85%
    second.pivot.set(1.5, 85);
    // 为围绕重点渲染 需要改变矩形的位置便于旋转效果
    second.position.set(app.screen.width / 2 + 1.5, app.screen.height / 2);
    // second.rotation = 6 * (Math.PI / 180);
    const positionPiovt = second.toGlobal(new Point(1.5, 85));
    // 矩形的中心点创建一个圆
    const pivotCircle = new Graphics().circle(0, 0, 4).fill("#FFD5AE").stroke({ width: 2, color: "#000" });
    pivotCircle.position.set(positionPiovt.x, positionPiovt.y);
    secondContainer.addChild(pivotCircle);
    // 添加分钟指针
    const min = new Graphics().rect(0, 0, 4, 80).fill("#333");
    min.pivot.set(2, 65);
    min.position.set(app.screen.width / 2 + 2, app.screen.height / 2);
    minter.addChild(min);

    // 添加时钟指针
    const hour = new Graphics().rect(0, 0, 4, 60).fill("#111");
    hour.pivot.set(2, 45);
    hour.position.set(app.screen.width / 2 + 2, app.screen.height / 2);
    hours.addChild(hour);

    const date = new Date();
    // 1s是6° 即 6 * (Π/180)
    const seconds = date.getSeconds();
    second.rotation = seconds * 6 * (Math.PI / 180);
    min.rotation = date.getMinutes() * 6 * (Math.PI / 180);
    hour.rotation = date.getHours() * 6 * (Math.PI / 180);
    const calibration = addCalibration(app);
    clock.addChild(calibration);

    app.stage.addChild(clock);
    app.ticker.add((delte) => {
      second.rotation += 6 * (Math.PI / 180) * (delte.deltaTime / 60);
      if (second.rotation >= Math.PI * 2) {
        second.rotation %= Math.PI * 2;
        gsap.to(min, {
          rotation: `+= ${6 * (Math.PI / 180)}`,
        });
      }
      if (min.rotation >= Math.PI * 2) {
        min.rotation %= Math.PI * 2;
        gsap.to(hour, {
          rotation: `+= ${6 * (Math.PI / 180)}`,
        });
      }
      if (hour.rotation >= Math.PI * 2) {
        hour.rotation %= Math.PI * 2;
      }
    });
  }

这里添加了时钟分钟和秒钟以及时钟的边框,在ticker里每秒钟转动6°,超过360°时重新开始计算,并设置分钟转动6°;

下面添加时钟的刻度addCalibration

// 刻度
  function addCalibration(app: Application<Renderer>) {
    const calibration = new Container();
    const zero = new Graphics().rect(0, 0, 4, 12).fill("#000");
    zero.position.set(app.screen.width / 2, app.screen.height / 2 - 105);
    calibration.addChild(zero);

    const three = new Graphics().rect(0, 0, 4, 12).fill("#000");
    three.rotation = Math.PI / 2;
    three.position.set(app.screen.width / 2 + 105, app.screen.height / 2);
    calibration.addChild(three);

    const six = new Graphics().rect(0, 0, 4, 12).fill("#000");
    six.pivot.set(2, 12);
    six.position.set(app.screen.width / 2, app.screen.height / 2 + 105);
    calibration.addChild(six);

    const nine = new Graphics().rect(0, 0, 4, 12).fill("#000");
    nine.rotation = Math.PI / 2;
    nine.pivot.set(2, 12);
    nine.position.set(app.screen.width / 2 - 105, app.screen.height / 2);
    calibration.addChild(nine);

    return calibration;
  }

时间关系 就不把剩下的刻度标出来了,最终效果为
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/691107.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Web 版 | 开源数据库设计软件 | drawdb

文章目录 简介快速运行方式 1:本地运行方式 2:Docker 构建并运行方式 3:Docker 运行参考🚀 目标: 安装一个 Web 版本的 ER 图设计软件! 👉 GitHub: https://github.com/drawdb-io/drawdb 【11.7k ⭐】 简介 DrawDB:Free, simple, and intuitive database design …

【iOS】UI——关于UIAlertController类(警告对话框)

目录 前言关于UIAlertController具体操作及代码实现总结 前言 在UI的警告对话框的学习中&#xff0c;我们发现UIAlertView在iOS 9中已经被废弃&#xff0c;我们找到UIAlertController来代替UIAlertView实现弹出框的功能&#xff0c;从而有了这篇关于UIAlertController的学习笔记…

Idea解决堆栈溢出

废话不说了&#xff0c;这问题搞了我两天&#xff0c;最近在用内网办公&#xff0c;没用公网&#xff0c;所以博客暂时没更新

堆排序-调整算法

个人主页点这里!~ 1.堆 了解堆排序首先要了解一下堆这个数据结构 堆&#xff08;Heap&#xff09;是一种特殊的树形数据结构&#xff0c;它通常被表示为一个完全二叉树或近似完全二叉树&#xff0c;并且满足堆性质&#xff08;Heap Property&#xff09;。堆主要分为两种&…

wordpress主题导航主题v4.16.2哈哈版

1.下载授权接口源码onenav-auth-api-v2.zip &#xff0c;在宝塔新建一个网站&#xff0c;域名为 auth.iotheme.cn&#xff0c;设置wordpress伪静态&#xff0c;申请ssl证书。将上面源码解压后上传到此网站根目录。 2. 在宝塔根目录etc下 hosts 中添加 127.0.0.1 auth.iotheme.…

Docker配置Redis集群以及主从扩容与缩容

基础镜像拉取 docker run -p 6379:6379 -d redis:6.0.8 配置文件以及数据卷挂载 # 开启密码验证&#xff08;可选&#xff09; requirepass 1234 # 允许redis外地连接&#xff0c;需要注释掉绑定的IP # bind 127.0.0.1 # 关闭保护模式&#xff08;可选&#xff09; protected-m…

13、SpringBoot 源码分析 - 自动配置深度分析六

SpringBoot 源码分析 - 自动配置深度分析六 refresh和自动配置大致流程AutoConfigurationImportSelector的fireAutoConfigurationImportEvents通知自动配置导入事件AutoConfigurationGroup的selectImports封装成Entry返回MyAutoConfiguration自动配置类创建META-INF文件夹和文件…

CST纳米光学 --- LSPR局部等离子激元共振,消光截面ECS,法诺共振

这期我们用自带的Drude散射粒子&#xff0c;计算消光截面。 查看模型&#xff0c;内核是Silica二氧化硅&#xff0c;正常的介质材料&#xff0c;半径是38纳米&#xff1a; 外围是Drude模型的金属材料包裹&#xff0c;半径48纳米&#xff0c;该材料的参数可由宏Materials->Cr…

多个p标签一行展示,溢出隐藏

一开始&#xff0c;我是让div包裹多个p标签&#xff0c;并让div“flex”布局&#xff0c;且单行溢出隐藏&#xff0c;可是发现当父元素或当前元素有flex时&#xff0c;text-overflow: ellipsis;是不生效的 大多数解决办法都是&#xff0c;不要flex&#xff0c;或者给div下的每个…

代码随想录算法训练营第四十九天 | 139.单词拆分、多重背包、背包问题总结

139.单词拆分 视频讲解&#xff1a; 动态规划之完全背包&#xff0c;你的背包如何装满&#xff1f;| LeetCode&#xff1a;139.单词拆分_哔哩哔哩_bilibili 代码随想录 解题思路 1.dp[i] 字符串的长度为i&#xff0c;dp[i]是否可以被组成 2.递推公式 if( [j,i] && d…

基于springboot开发的Java MES制造执行系统源码,全套源码,一款数字化管理平台源码 云MES系统源码

基于springboot开发的Java MES制造执行系统源码&#xff0c;全套源码&#xff0c;一款数字化管理平台源码 云MES系统源码 MES系统源码相关技术&#xff1a; ​技术架构&#xff1a;springboot vue-element-plus-admin 开发语言&#xff1a;Java 开发工具&#xff1a;idea 前…

【Unity3D小功能】Unity3D中UGUI-Text实现打字机效果

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享简书地址QQ群&#xff1a;398291828 大家好&#xff0c;我是佛系工程师☆恬静的小魔龙☆&#xff0c;不定时更新Unity开发技巧&#xff0c;觉得有用记得一键三连哦。 一、前言 需求要实现Text的打字机效果&#xff0c;一看居然…

【Linux】进程4——进程状态

1.进程状态 什么是状态&#xff1f; 每个人都有状态——颓废&#xff0c;阳光&#xff0c;积极向上。。。。 进程也有状态 在操作系统中&#xff0c;由于进程的数量是非常多的&#xff0c;而系统的资源又非常少&#xff0c;所以不可能每一个进程在每时每刻都会处于上处理机运…

Python语言读取图像

import cv2 import numpy as np width 640 # 图像宽度height 480 # 图像高度channels 3 # 颜色通道数imgEmpty np.empty((height, width, channels), np.uint8) # 创建空白数组imgBlack np.zeros((height, width, channels), np.uint8) # 创建黑色图像 RGB0imgWhite …

微型丝杆与滚珠丝杆性能差异与适用场景!

滚珠丝杆是工具机械和精密机械上最常使用的传动元件&#xff0c;其主要功能是将旋转运动转换成线性运动&#xff0c;或将扭矩转换成轴向反复作用力。同时兼具高精度、可逆性和高效率的特点。而微型丝杆是一种直径为0.5mm以下且线性误差在几微米以内&#xff0c;精度高、传动稳定…

开发uniapp 小程序时遇到的问题

1、【微信开发者工具报错】routeDone with a webviewId XXX that is not the current page 解决方案: 在app.json 中添加 “lazyCodeLoading”: “requiredComponents” uniapp的话加到manifest.json下的mp-weixin 外部链接文章&#xff1a;解决方案文章1 解决方案文章2 &qu…

LLM的基础模型2:Transformer的组成模块

Transformer是一种先进的语言模型&#xff0c;它在预测下一个单词或标记方面与传统的语言模型有所不同&#xff0c;但仍然遵循相同的基本原理。Transformer通过一系列复杂的步骤&#xff0c;将输入的标记序列转换为能够进行预测的丰富向量序列。 在Transformer中&#xff0c;输…

反转链表 (oj题)

一、题目链接 https://leetcode.cn/problems/reverse-linked-list/submissions/538124207 二、题目思路 1.定义三个指针&#xff0c;p1先指向NULL p2指向头结点 p3指向第二个结点 2.p2的next指向p1。然后移动指针&#xff0c;p1来到p2的位置&#xff0c;p2来到p3的位置&…

二开版微交易系统

下载地址&#xff1a;二开版微交易系统

验证码案例

目录 前言 一、Hutool工具介绍 1.1 Maven 1.2 介绍 1.3 实现类 二、验证码案例 2.1 需求 2.2 约定前后端交互接口 2.2.1 需求分析 2.2.2 接口定义 2.3 后端生成验证码 2.4 前端接收验证码图片 2.5 后端校验验证码 2.6 前端校验验证码 2.7 后端完整代码 前言…