全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C++如何实现一个简单的向量数学库_为C++图形学编程编写Vec3和Mat4类

答案:文章介绍了在C++图形学编程中实现基础数学库的方法,包含Vec3类用于三维向量运算如加减、点积、叉积和单位化,Mat4类实现4x4矩阵的乘法与向量变换,支持平移、旋转、缩放及透视投影等操作,并通过Transform工具类提供常用变换函数,最后给出组合变换的使用示例,适用于教学和原型开发。

在C++图形学编程中,向量(Vec3)和4x4矩阵(Mat4)是基础中的基础。实现一个简单的数学库能帮助你理解底层运算,同时为后续的渲染、变换、光照计算打下基础。下面教你如何从零开始写一个轻量级但实用的 Vec3 和 Mat4 类。

Vec3:三维向量类

Vec3 表示三维空间中的点或方向,支持加减、数乘、点积、叉积等操作。

基本结构:

// Vec3.h #pragma once #include

class Vec3 { public: float x, y, z;

// 构造函数
Vec3() : x(0), y(0), z(0) {}
Vec3(float x, float y, float z) : x(x), y(y), z(z) {}

// 向量加法
Vec3 operator+(const Vec3& other) const {
    return Vec3(x + other.x, y + other.y, z + other.z);
}

// 向量减法
Vec3 operator-(const Vec3& other) const {
    return Vec3(x - other.x, y - other.y, z - other.z);
}

// 数乘
Vec3 operator*(float scalar) const {
    return Vec3(x * scalar, y * scalar, z * scalar);
}

// 点积
float dot(const Vec3& other) const {
    return x * other.x + y * other.y + z * other.z;
}

// 叉积
Vec3 cross(const Vec3& other) const {
    return Vec3(
        y * other.z - z * other.y,
        z * other.x - x * other.z,
        x * other.y - y * other.x
    );
}

// 向量长度
float length() const {
    return std::sqrt(x*x + y*y + z*z);
}

// 单位化
Vec3 normalize() const {
    float len = length();
    return len != 0 ? *this * (1.0f / len) : Vec3(0, 0, 0);
}

};

// 支持 scalar vector inline Vec3 operator(float scalar, const Vec3& v) { return v * scalar; }

Mat4:4x4矩阵类

Mat4 用于表示空间变换:平移、旋转、缩放和投影。我们用列主序存储16个浮点数。

// Mat4.h #pragma once

class Mat4 { public: float m[16]; // 列主序:m[0-3] 是第一列

// 单位矩阵构造
Mat4() {
    for (int i = 0; i zuojiankuohaophpcn 16; i++) {
        m[i] = (i % 5 == 0) ? 1.0f : 0.0f; // 对角线为1
    }
}

// 手动设置元素
void set(int row, int col, float value) {
    m[col * 4 + row] = value; // 列主序索引
}

// 矩阵乘法
Mat4 operator*(const Mat4& other) const {
    Mat4 result;
    for (int i = 0; i zuojiankuohaophpcn 4; i++) {
        for (int j = 0; j zuojiankuohaophpcn 4; j++) {
            float sum = 0;
            for (int k = 0; k zuojiankuohaophpcn 4; k++) {
                sum += m[i * 4 + k] * other.m[k * 4 + j];
            }
            result.m[i * 4 + j] = sum;
        }
    }
    return result;
}

// 矩阵与向量相乘(齐次坐标)
Vec3 operator*(const Vec3& v) const {
    float x = m[0]*v.x + m[4]*v.y + m[8]*v.z + m[12];
    float y = m[1]*v.x + m[5]*v.y + m[9]*v.z + m[13];
    float z = m[2]*v.x + m[6]*v.y + m[10]*v.z + m[14];
    float w = m[3]*v.x + m[7]*v.y + m[11]*v.z + m[15];
    if (w != 0 && w != 1) {
        return Vec3(x/w, y/w, z/w);
    }
    return Vec3(x, y, z);
}

};

常用变换函数

静态函数生成特定变换矩阵,方便调用。

// TransformUtils.h #pragma once #include "Mat4.h" #include

class Transform { public: // 平移矩阵 static Mat4 translate(float x, float y, float z) { Mat4 mat; mat.set(0, 3, x); mat.set(1, 3, y); mat.set(2, 3, z); return mat; }

// 缩放矩阵
static Mat4 scale(float x, float y, float z) {
    Mat4 mat;
    mat.set(0, 0, x);
    mat.set(1, 1, y);
    mat.set(2, 2, z);
    return mat;
}

// 绕X轴旋转
static Mat4 rotateX(float rad) {
    Mat4 mat;
    float c = cosf(rad);
    float s = sinf(rad);
    mat.set(1, 1, c); mat.set(1, 2, -s);
    mat.set(2, 1, s); mat.set(2, 2, c);
    return mat;
}

// 绕Y轴旋转
static Mat4 rotateY(float rad) {
    Mat4 mat;
    float c = cosf(rad);
    float s = sinf(rad);
    mat.set(0, 0, c); mat.set(0, 2, s);
    mat.set(2, 0, -s); mat.set(2, 2, c);
    return mat;
}

// 绕Z轴旋转
static Mat4 rotateZ(float rad) {
    Mat4 mat;
    float c = cosf(rad);
    float s = sinf(rad);
    mat.set(0, 0, c); mat.set(0, 1, -s);
    mat.set(1, 0, s); mat.set(1, 1, c);
    return mat;
}

// 透视投影矩阵(简化版)
static Mat4 perspective(float fov, float aspect, float near, float far) {
    Mat4 mat;
    float f = 1.0f / tanf(fov * 0.5f);
    mat.set(0, 0, f / aspect);
    mat.set(1, 1, f);
    mat.set(2, 2, (far + near) / (near - far));
    mat.set(2, 3, (2 * far * near) / (near - far));
    mat.set(3, 2, -1);
    mat.set(3, 3, 0);
    return mat;
}

};

使用示例

#include "Vec3.h" #include "TransformUtils.h" #include iostream>

int main() { Vec3 pos(1, 0, 0);

Mat4 model = Transform::translate(2, 0, 0);
Mat4 rot   = Transform::rotateZ(3.14159f / 4.0f);
Mat4 scale = Transform::scale(2, 2, 2);

Mat4 transform = model * rot * scale;
Vec3 transformed = transform * pos;

std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Transformed: (" 
          zuojiankuohaophpcnzuojiankuohaophpcn transformed.x zuojiankuohaophpcnzuojiankuohaophpcn ", " 
          zuojiankuohaophpcnzuojiankuohaophpcn transformed.y zuojiankuohaophpcnzuojiankuohaophpcn ", " 
          zuojiankuohaophpcnzuojiankuohaophpcn transformed.z zuojiankuohaophpcnzuojiankuohaophpcn ")\n";

return 0;

}

基本上就这些。这个简易数学库没有过度优化,但足够教学和原型开发使用。你可以逐步添加更多功能,比如欧拉角转矩阵、LookAt 矩阵、逆矩阵等。关键是理解每一步运算的几何意义。


# 工具  # ai  # c++  # ios  # stream  # cos  # Static  # Float  # include  # const  # int  # class  # public  # operator  # transform  # 加减  # 你可以  # 适用于  # 教你如何  # 从零开始  # 简化版  # 欧拉  # 浮点数  # 帮助你  # len 


相关文章: 网站制作难吗安全吗,做一个网站需要多久时间?  如何在万网主机上快速搭建网站?  如何在腾讯云免费申请建站?  制作电商网页,电商供应链怎么做?  如何通过服务器快速搭建网站?完整步骤解析  建站之星伪静态规则如何正确配置?  建站之星后台管理:高效配置与模板优化提升用户体验  网站插件制作软件免费下载,网页视频怎么下到本地插件?  建站之星会员如何解锁更多建站功能?  如何高效生成建站之星成品网站源码?  如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  再谈Python中的字符串与字符编码(推荐)  如何用5美元大硬盘VPS安全高效搭建个人网站?  北京制作网站的公司,北京铁路集团官方网站?  如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本  高性能网站服务器部署指南:稳定运行与安全配置优化方案  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  制作网站的软件免费下载,免费制作app哪个平台好?  怀化网站制作公司,怀化新生儿上户网上办理流程?  定制建站策划方案_专业建站与网站建设方案一站式指南  网站制作公司广州有几家,广州尚艺美发学校网站是多少?  已有域名和空间,如何快速搭建网站?  网站制作话术技巧,网站推广做的好怎么话术?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  香港服务器租用每月最低只需15元?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  如何在云指建站中生成FTP站点?  如何在七牛云存储上搭建网站并设置自定义域名?  家具网站制作软件,家具厂怎么跑业务?  微信h5制作网站有哪些,免费微信H5页面制作工具?  三星网站视频制作教程下载,三星w23网页如何全屏?  linux top下的 minerd 木马清除方法  如何高效完成自助建站业务培训?  网站制作免费,什么网站能看正片电影?  如何通过虚拟主机空间快速建站?  建站之星Pro快速搭建教程:模板选择与功能配置指南  如何选择高效可靠的多用户建站源码资源?  建站VPS选购需注意哪些关键参数?  北京专业网站制作设计师招聘,北京白云观官方网站?  网站设计制作公司地址,网站建设比较好的公司都有哪些?  制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?  如何配置IIS站点权限与局域网访问?  定制建站流程解析:需求评估与SEO优化功能开发指南  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  建站之星安装模板失败:服务器环境不兼容?  如何快速搭建FTP站点实现文件共享?  网站制作的步骤包括,正确网址格式怎么写?  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。