标题:
stm32+oled组成显示3d旋转图演示视频
[打印本页]
作者:
djjdjjm8898
时间:
2018-7-25 12:41
标题:
stm32+oled组成显示3d旋转图演示视频
提到3d渲染引,通常只会用,现在呢把这东西移植到了stm32上,大家可以学习下,不光能旋转立方体,只要是简单的3d图(例如纸飞机)都能显示
视频:
https://v.youku.com/v_show/id_XMzc0NDEyNzc4NA==.html
作者:
admin
时间:
2018-7-25 16:36
有源码吗?没有源码不要发技术区,会导致扣分的
作者:
djjdjjm8898
时间:
2018-8-2 08:45
贴上源码
float cube[8][3]={{-15,-15,-15},{-15,15,-15},{15,15,-15},{15,-15,-15},{-15,-15,15},{-15,15,15},{15,15,15},{15,-15,15}};//立方体坐标
int lineid[25]={1,2,2,3,3,4,4,1,5,6,6,7,7,8,8,5,8,4,7,3,6,2,5,1};//记录点之间连接顺序
float *matconv(float *a,float b[3][3]){//计算矩阵算法
float res[3];
int i;
for(i=0;i<3;i++){
res[i]=b[i][0]*a[0]+b[i][1]*a[1]+b[i][2]*a[2];
}
for(i=0;i<3;i++){
a[i]=res[i];
}
return a;
}
void rotate(float *obj,float x,float y,float z){//旋转这个向量
float rz[3][3]={{cos(z),sin(z),0},{sin(z),cos(z),0},{0,0,0}};
float ry[3][3]={{0,0,0},{0,cos(y),sin(y)},{0,sin(y),cos(y)}};
float rx[3][3]={{cos(x),0,sin(x)},{0,0,0},{sin(x),0,cos(x)}};
matconv(matconv(matconv(obj,rz),ry),rx);
}
作者:
ch12063119
时间:
2018-8-2 17:03
楼主能分享一下程序吗?
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1