我需要将一个glm数学库mat4放入sqlite3 BLOB并返回。什么是最有效的方法?将mat4序列化为字节?,将mat4转换为浮点数组? BLOB不会直接使用mat4
将mat4的强力转换添加到浮点数组
:) using namespace glm;
mat4 fM;
float fma[16];
vec4 t0 = fM[0];
vec4 t1 = fM[1];
vec4 t2 = fM[2];
vec4 t3 = fM[3];
fma[0] = t0[0];
fma[1] = t0[1];
fma[2] = t0[2];
fma[3] = t0[3];
fma[4] = t1[0];
fma[5] = t1[1];
fma[6] = t1[2];
fma[7] = t1[3];
fma[8] = t2[0];
fma[9] = t2[1];
fma[10] = t2[2];
fma[11] = t2[3];
fma[12] = t3[0];
fma[13] = t3[1];
fma[14] = t3[2];
fma[15] = t3[3];
这已经过测试才能正常工作 - 但应该有更好的方法。 从float [16]到mat4的转换由glm库glm / gtc / type_ptr.hpp处理 - 按预期工作。 sqlite3中的BLOB将直接采用float数组。
解决:
#include <glm/glm.hpp>
#include <glm/gtc/type_ptr.hpp>
float *fM;
glm::mat4 matrix;
fM = glm::value_ptr(matrix);
sqlite3_bind_blob(stmt, 0, fM, sizeof(fM), SQLITE_STATIC);
上面将glm :: mat4的值转换为float数组,然后可以将其作为单个BLOB类型保存在sqlite3中
答案 0 :(得分:1)
目前我正在做类似的事情,所以我希望这会对你有所帮助。 我正在做的是:将矩阵转换为浮点数,然后转换为字符串并将其存储在xml中,您可以通过将浮点数组作为字符串存储在SQLite数据库中来执行相同的操作。