gl-matrix 库简介

gl-matrix 库简介

gl-matrix 是一个高性能的 JavaScript 矩阵和向量库,专门为 WebGL 和其他 3D 图形应用设计。它提供了处理 2D、3D 和 4D 向量以及矩阵运算的高效方法。

主要特性

  1. 高性能:经过高度优化,执行速度快
  2. 轻量级:体积小,无依赖
  3. 全面:包含各种向量和矩阵运算功能
  4. 模块化:可以按需导入特定功能

基本用法

安装

npm install gl-matrix

或通过 CDN 使用:

<script src="https://cdn.jsdelivr.net/npm/gl-matrix@3.4.3/gl-matrix-min.js"></script>

核心模块

  • vec2 - 2D 向量操作
  • vec3 - 3D 向量操作
  • vec4 - 4D 向量操作
  • mat2 - 2x2 矩阵操作
  • mat2d - 2x3 仿射矩阵操作
  • mat3 - 3x3 矩阵操作
  • mat4 - 4x4 矩阵操作
  • quat - 四元数操作

示例代码

import { mat4, vec3 } from 'gl-matrix';// 创建一个单位矩阵
const modelViewMatrix = mat4.create();// 平移矩阵
mat4.translate(modelViewMatrix, modelViewMatrix, [0, 0, -5]);// 旋转矩阵 (绕Y轴旋转45度)
mat4.rotateY(modelViewMatrix, modelViewMatrix, Math.PI / 4);// 缩放矩阵
mat4.scale(modelViewMatrix, modelViewMatrix, [1, 1, 1]);// 向量变换
const position = vec3.fromValues(1, 0, 0);
const transformedPosition = vec3.create();
vec3.transformMat4(transformedPosition, position, modelViewMatrix);

常用操作

向量操作

  • 创建向量:vec3.create()
  • 向量加法:vec3.add(out, a, b)
  • 向量点积:vec3.dot(a, b)
  • 向量叉积:vec3.cross(out, a, b)
  • 向量归一化:vec3.normalize(out, a)

矩阵操作

  • 创建矩阵:mat4.create()
  • 矩阵乘法:mat4.multiply(out, a, b)
  • 透视投影:mat4.perspective(out, fovy, aspect, near, far)
  • 视图矩阵:mat4.lookAt(out, eye, center, up)

性能建议

  1. 尽量重用对象而不是频繁创建新对象
  2. 使用 out 参数接收结果而不是返回新对象
  3. 在动画循环外预先计算不变化的矩阵

gl-matrix 是 WebGL 和 3D 图形编程中非常实用的工具库,能够高效处理各种线性代数运算。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大语言模型的训练、微调及压缩技术

The rock can talk — not interesting. The rock can read — that’s interesting. &#xff08;石头能说话&#xff0c;不稀奇。稀奇的是石头能读懂。&#xff09; ----硅谷知名创业孵化器 YC 的总裁 Gar Tan 目录 1. 什么是大语言模型&#xff1f; 2. 语言建模&#xff…

那些能够直接编译到 WebAssembly 的 Rust Crates

一、为什么有的 Crate “跑不起来”&#xff1f; 在最常见的 浏览器环境 中&#xff0c;Wasm 沙盒本身缺少操作系统功能和标准 C 运行时支持。以下几类依赖若出现在 crate 中&#xff0c;就很可能导致编译或运行时出错&#xff1a; C / 系统库绑定 浏览器环境没有 libc、dlope…

Ext系列⽂件系统

Ext系列⽂件系统 1. 理解硬件1.1 磁盘的物理结构1.2 磁盘的存储结构1.3 磁盘的逻辑结构理解过程实际过程 1.4 CHS&&LBA地址 2. 引入文件系统块分区innode 3. Ext2文件系统3.1 宏观认识3.2 block group3.3 块组内部3.3.1 GDT&#xff08;Group Descriptor Table&#xf…

元宇宙概念兴起,B 端数字孪生迎来哪些新机遇?

在科技飞速发展的当下&#xff0c;元宇宙概念如同一颗璀璨新星&#xff0c;迅速吸引了全球的目光。随着元宇宙的兴起&#xff0c;与之紧密相关的 B 端数字孪生技术也迎来了前所未有的发展机遇。元宇宙与 B 端数字孪生的融合&#xff0c;正悄然改变着多个行业的运作模式&#xf…

从数字化到智能化,百度 SRE 数智免疫系统的演进和实践

1. 为什么 SRE 需要数智免疫系统&#xff1f; 2022 年 10 月&#xff0c;在 Gartner 公布的 2023 年十大战略技术趋势中提到了「数字免疫系统」的概念&#xff0c;旨在通过结合数据驱动的一系列手段来提高系统的弹性和稳定性。 在过去 2 年的时间里&#xff0c;百度基于该…

4月18日复盘

4月18日复盘 一、深度学习概述 ​ 传统机器学习算法依赖人工设计特征、提取特征&#xff0c;而深度学习依赖算法自动提取特征。深度学习模仿人类大脑的运行方式&#xff0c;从大量数据中学习特征&#xff0c;这也是深度学习被看做黑盒子、可解释性差的原因。 ​ 随着算力的提…

C++每日训练 Day 17:构建响应式加载动画与异步数据处理

&#x1f4d8; 本篇目标是&#xff1a;在 GUI 信号机制基础上&#xff0c;构建一个完整的“点击按钮 → 显示加载动画 → 异步加载数据 → 显示结果”的响应式界面流程。通过协程挂起/恢复机制&#xff0c;实现清晰的异步逻辑&#xff0c;避免回调地狱。 &#x1f501; 回顾 Da…

PyTorch深度学习框架60天进阶学习计划 - 第45天:神经架构搜索(二)

PyTorch深度学习框架60天进阶学习计划 - 第45天&#xff1a;神经架构搜索&#xff08;二&#xff09; 第二部分&#xff1a;权重共享策略的计算效率优化 8. 权重共享的理论基础 权重共享策略的理论基础来自于多任务学习(Multi-Task Learning, MTL)和迁移学习(Transfer Learn…

深入理解分布式缓存 以及Redis 实现缓存更新通知方案

一、分布式缓存简介 1. 什么是分布式缓存 分布式缓存&#xff1a;指将应用系统和缓存组件进行分离的缓存机制&#xff0c;这样多个应用系统就可以共享一套缓存数据了&#xff0c;它的特点是共享缓存服务和可集群部署&#xff0c;为缓存系统提供了高可用的运行环境&#xff0c…

记录学习的第二十九天

还是力扣每日一题。 本来想着像昨天一样两个循环搞定的&#xff0c;就下面&#x1f447;&#x1f3fb; 不过&#xff0c;结果肯定是超时啦&#xff0c;中等题是吧。 正确答案是上面的。 之后就做了ls题单第一部分&#xff0c;首先是定长滑窗问题 这种题都是有套路的&#xff0…

Win11关闭防火墙方法

网上讲的win11的方法都试过了&#xff0c;但是在实际使用过程中还是会显示有威胁杀掉原本要使用的程序&#xff0c;下面我介绍的这个方法亲测有效&#xff0c;必须百分百关掉防火墙 搜索安全中心打开Windows安全中心 打开病毒和威胁防护 点击管理设置 将设置中所有显示开的都…

几个常用的快速处理服务器命令和故障排查

1. 查看剩余的内存 free -m top //当然了还有top可以实时观测 显示剩余内存,以M为单位. 2. 查看剩余的空间 df -h 显示指定磁盘文件的可用空间。如果没有文件名被指定&#xff0c;则所有当前被挂载的文件系统的可用空间将被显示 3.找出大文件的常用方法 du --max-depth1 -h –输…

Spring MVC 全栈指南:RESTful 架构、核心注解与 JSON 实战解析

目录 RESTful API 设计规范Spring MVC 核心注解解析静态资源处理策略JSON 数据交互全解高频问题与最佳实践 一、RESTful API 设计规范 1.1 核心原则 原则说明示例 URI资源为中心URI 使用名词&#xff08;复数形式&#xff09;/users ✔️ /getUser ❌HTTP 方法语义化GET&…

探索 JavaScript 中的 Promise 高级用法与实战

在现代 Web 开发中&#xff0c;异步编程已成为不可或缺的一部分。JavaScript 作为 Web 开发的核心语言&#xff0c;提供了多种处理异步操作的方式&#xff0c;其中 Promise 对象因其简洁、强大的特性而备受青睐。本文将深入探讨 Promise 的高级用法&#xff0c;并结合实际案例&…

《软件设计师》复习笔记(14.1)——面向对象基本概念、分析设计测试

目录 一、面向对象基本概念 对象&#xff08;Object&#xff09; 类&#xff08;Class&#xff09; 抽象&#xff08;Abstraction&#xff09; 封装&#xff08;Encapsulation&#xff09; 继承&#xff08;Inheritance&#xff09; 多态&#xff08;Polymorphism&#…

ubuntu22.04 安装有度即时通

1.官网下载deb的安装包 官网地址&#xff1a;有度客户端下载-有度 注意&#xff1a;这个网站的下载是有时间限制的&#xff0c;有时候无法下载 需要对应系统版本&#xff0c;否则无法使用 我之前使用了dpkg安装了一个旧版本&#xff0c;卸载使用以下命名行&#xff1a; 使用…

ValueError: model.embed_tokens.weight doesn‘t have any device set

ValueError: model.embed_tokens.weight doesn’t have any device set model.embed_tokens.weight 通常在深度学习框架(如 PyTorch)中使用,一般是在处理自然语言处理(NLP)任务时,用于指代模型中词嵌入层(Embedding layer)的权重参数。下面详细解释: 词嵌入层的作用 …

如何提高单元测试的覆盖率

一、定位未覆盖的代码 ​利用 IDEA 的覆盖率工具​&#xff1a; 右键测试类 → ​Run with Coverage&#xff0c;或使用 AltShiftF10&#xff08;Windows&#xff09;打开运行菜单选择覆盖率。​查看高亮标记​&#xff1a; ​绿色​&#xff1a;已覆盖代码行。​红色​&#x…

聚合直播-Simple Live-v1.7.7-全网直播平台能在一个软件上看完

聚合直播-Simple Live 链接&#xff1a;https://pan.xunlei.com/s/VOO7u3o4FNL_XA9VJ6l7KBNfA1?pwdyrau# 聚合直播-Simple Live-v1.7.7-全网直播平台能在一个软件上看完

三大等待和三大切换

三大等待 1、三大等待&#xff1a;等待的方式有三种&#xff1a;强制等待&#xff0c;隐性等待&#xff0c;显性等待。 1、强制等待&#xff1a;time.sleep(2)&#xff0c;秒 优点&#xff1a;使用简单缺点&#xff1a;等待时间把握不准&#xff0c;容易造成时间浪费或者等待时…