IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> Java实现TF类矩阵变换--三维坐标转换 -> 正文阅读

[游戏开发]Java实现TF类矩阵变换--三维坐标转换


在这里插入图片描述


前言

工作中需要使用Java实现对三维坐标的转换,因为没有现成的库实现,所以封装了一个类实现了基本的矩阵变换。


一、引入math下的矩阵基本库

        <dependency>
            <groupId>org.saintandreas</groupId>
            <artifactId>math</artifactId>
            <version>1.0.4</version>
        </dependency>

二、定义Transform类



import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.Accessors;
import org.saintandreas.math.Matrix3f;
import org.saintandreas.math.Quaternion;
import org.saintandreas.math.Vector3f;

/**
 * @Author wangzeming
 * @Date 2022/1/6 9:09
 */
@Data
@Accessors(chain = true)
@AllArgsConstructor
@NoArgsConstructor
public class Transform {

    private Matrix3f m_basis;

    private Vector3f m_origin;

    @Data
    @Accessors(chain = true)
    public static class Pose {
        private float x;
        private float y;
        private float z;
        private float yaw;
    }

    public void setM_basis(Quaternion quaternion) {
        this.m_basis = quaternion.toRotationMatrix();
    }

    public Transform inverse() {
        Matrix3f inv = this.m_basis.transpose();
        Vector3f negative = getNegative(this.getM_origin());
        return new Transform(inv, inv.mult(negative));
    }

    public static Pose getPose(Transform transform) {
        Vector3f m_origin = transform.getM_origin();
        Quaternion quaternion = new Quaternion().apply(transform.getM_basis());
        float yaw = getYaw(quaternion);
        return new Pose().setX(m_origin.getX())
                .setY(m_origin.getY())
                .setZ(m_origin.getZ())
                .setYaw(yaw);
    }

    public Vector3f getNegative(Vector3f vector3f) {
        return new Vector3f(-vector3f.getX(), -vector3f.getY(), -vector3f.getZ());
    }

    /**
     * Transform * Transform
     */
    public static Transform multiplyTransform (Transform t1, Transform t2) {
        return new Transform(t1.getM_basis().mult(t2.getM_basis()), multiplyVector3f(t1, t2.getM_origin()));
    }

    /**
     * Transform * Vector3f
     */
    public static Vector3f multiplyVector3f (Transform transform, Vector3f x) {
        return new Vector3f(transform.getM_basis().getRow(0).dot(x) + transform.getM_origin().getX(),
                        transform.getM_basis().getRow(1).dot(x) + transform.getM_origin().getY(),
                        transform.getM_basis().getRow(2).dot(x) + transform.getM_origin().getZ());
    }

    public static float getYaw(Quaternion q) {
        float w = q.getW();
        float x = q.getX();
        float y = q.getY();
        float z = q.getZ();
        float siny_cosp = 2 * (w * z + x * y);
        float cosy_cosp = 1 - 2 * (y * y + z * z);
        return (float) Math.atan2(siny_cosp, cosy_cosp);
    }

    /**
     * tOne: 绝对坐标
     * tTwo: 绝对坐标
     * getRelativePose: tTwo相对于tOne的相对坐标
     */
    public static Transform.Pose getRelativePose(Transform tOne, Transform tTwo) {
        Transform tOneInverse = tOne.inverse();
        Transform multiplyTransform = Transform.multiplyTransform(tOneInverse, tTwo);
        return Transform.getPose(multiplyTransform);
    }

    /**
     * absoluteTF: 绝对坐标
     * relativeTF: 相对坐标
     */
    public static Transform.Pose getAbsolutePose(Transform absoluteTF, Transform relativeTF) {
        Transform multiplyTransform = Transform.multiplyTransform(absoluteTF, relativeTF);
        return Transform.getPose(multiplyTransform);
    }

    public static Transform getTransform(Double x, Double y, Double r) {
        Vector3f vector3f = new Vector3f(x.floatValue(), y.floatValue(), 0);
        Quaternion quaternion = Quaternion.fromAngles(0, 0, r.floatValue());
        Transform transform = new Transform();
        transform.setM_origin(vector3f)
                .setM_basis(quaternion);
        return transform;
    }
}

三、如何使用?

  1. A点坐标
Transform pointA = getTransform(x1, y1, r1);
  1. B点坐标
Transform pointB = getTransform(x, y, r);
  1. 计算A点相对于B点的相对坐标?
Transform.Pose relativeA = getRelativePose(pointB , pointA);
  1. 根据相对坐标计算绝对坐标?
Pose pose= getAbsolutePose(pointB , relativeA);

总结

揣到兜里的才是自己的!

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-04-15 00:35:02  更:2022-04-15 00:35:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 21:01:49-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码