git-svn-id: https://svn.code.sf.net/p/freeglut/code/trunk@837 7f0cb862-5218-0410-a997-914c9d46530a
17 lines
325 B
C
17 lines
325 B
C
#include <math.h>
|
|
#include "vmath.h"
|
|
|
|
quat_t quat_rotate(quat_t q, float angle, float x, float y, float z)
|
|
{
|
|
quat_t rq;
|
|
float half_angle = angle * 0.5;
|
|
float sin_half = sin(half_angle);
|
|
|
|
rq.w = cos(half_angle);
|
|
rq.x = x * sin_half;
|
|
rq.y = y * sin_half;
|
|
rq.z = z * sin_half;
|
|
|
|
return quat_mul(q, rq);
|
|
}
|