我正在使用 OpenGL 数学库 ( glm.g-truc.net ) 并想glm::mat4
用浮点数组初始化 a 。
float aaa[16];
glm::mat4 bbb(aaa);
这行不通。
我想解决方案很简单,但我不知道该怎么做。我找不到关于 glm 的好文档。我会很感激一些有用的链接。
我正在使用 OpenGL 数学库 ( glm.g-truc.net ) 并想glm::mat4
用浮点数组初始化 a 。
float aaa[16];
glm::mat4 bbb(aaa);
这行不通。
我想解决方案很简单,但我不知道该怎么做。我找不到关于 glm 的好文档。我会很感激一些有用的链接。
虽然没有构造函数,但 GLM 在glm/gtc/type_ptr.hpp中包含 make_* 函数:
#include <glm/gtc/type_ptr.hpp>
float aaa[16];
glm::mat4 bbb = glm::make_mat4(aaa);
也可以直接复制内存:
float aaa[16] = {
1, 2, 3, 4,
5, 6, 7, 8,
9, 10, 11, 12,
13, 14, 15, 16
};
glm::mat4 bbb;
memcpy( glm::value_ptr( bbb ), aaa, sizeof( aaa ) );
您可以编写一个适配器函数:
template<typename T>
tvec4<T> tvec4_from_t(const T *arr) {
return tvec4<T>(arr[0], arr[1], arr[2], arr[3]);
}
template<typename T>
tmat4<T> tmat4_from_t(const T *arr) {
return tmat4<T>(tvec4_from_t(arr), tvec4_from_t(arr + 4), tvec4_from_t(arr + 8), tvec4_from_t(arr + 12));
}
// later
float aaa[16];
glm::mat4 bbb = tmac4_from_t(aaa);