metasurf
diff examples/volume/src/cam.c @ 3:52664d3451ad
added volume rendering example
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Tue, 25 Oct 2011 13:30:03 +0300 |
parents | |
children |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/examples/volume/src/cam.c Tue Oct 25 13:30:03 2011 +0300 1.3 @@ -0,0 +1,216 @@ 1.4 +#include <math.h> 1.5 +#include "cam.h" 1.6 + 1.7 +#if defined(__APPLE__) && defined(__MACH__) 1.8 +#include <OpenGL/gl.h> 1.9 +#else 1.10 +#include <GL/gl.h> 1.11 +#endif 1.12 + 1.13 +#define DR (M_PI / 180.0) 1.14 +#define DEG_TO_RAD(x) ((x) * DR) 1.15 + 1.16 +typedef struct vec3 { 1.17 + float x, y, z; 1.18 +} vec3_t; 1.19 + 1.20 +/* viewing parameters */ 1.21 +#define DEF_THETA 0 1.22 +#define DEF_PHI 0 1.23 +#define DEF_DIST 0 1.24 +#define DEF_X 0 1.25 +#define DEF_Y 0 1.26 +#define DEF_Z 0 1.27 + 1.28 +static float cam_theta = DEF_THETA, cam_phi = DEF_PHI; 1.29 +static float cam_dist = DEF_DIST; 1.30 +static vec3_t cam_pos = {DEF_X, DEF_Y, DEF_Z}; 1.31 + 1.32 +/* projection parameters */ 1.33 +#define DEF_VFOV 45.0 1.34 +#define DEF_ASPECT 1.3333333 1.35 +#define DEF_NEAR 1.0 1.36 +#define DEF_FAR 1000.0 1.37 + 1.38 +static float vfov = DEF_VFOV; 1.39 +static float aspect = DEF_ASPECT; 1.40 +static float nearclip = DEF_NEAR, farclip = DEF_FAR; 1.41 + 1.42 +/* stereo parameters */ 1.43 +#define DEF_EYE_SEP 0.1 1.44 +#define DEF_FOCUS_DIST 1.0 1.45 + 1.46 +static float eye_sep = DEF_EYE_SEP; 1.47 +static float focus_dist = DEF_FOCUS_DIST; 1.48 + 1.49 +static float pan_speed = 0.001; 1.50 +static float rot_speed = 0.5; 1.51 +static float zoom_speed = 0.1; 1.52 + 1.53 +static float vmin_deg = -90.0, vmax_deg = 90.0; 1.54 + 1.55 +void cam_reset(void) 1.56 +{ 1.57 + cam_reset_view(); 1.58 + cam_reset_proj(); 1.59 + cam_reset_stereo(); 1.60 +} 1.61 + 1.62 +void cam_reset_view(void) 1.63 +{ 1.64 + cam_theta = DEF_THETA; 1.65 + cam_phi = DEF_PHI; 1.66 + cam_dist = DEF_DIST; 1.67 + cam_pos.x = DEF_X; 1.68 + cam_pos.y = DEF_Y; 1.69 + cam_pos.z = DEF_Z; 1.70 +} 1.71 + 1.72 +void cam_reset_proj(void) 1.73 +{ 1.74 + vfov = DEF_VFOV; 1.75 + aspect = DEF_ASPECT; 1.76 + nearclip = DEF_NEAR; 1.77 + farclip = DEF_FAR; 1.78 +} 1.79 + 1.80 +void cam_reset_stereo(void) 1.81 +{ 1.82 + eye_sep = DEF_EYE_SEP; 1.83 + focus_dist = DEF_FOCUS_DIST; 1.84 +} 1.85 + 1.86 +void cam_set_vrange(float min_deg, float max_deg) 1.87 +{ 1.88 + vmin_deg = min_deg; 1.89 + vmax_deg = max_deg; 1.90 +} 1.91 + 1.92 +void cam_move(float x, float y, float z) 1.93 +{ 1.94 + cam_pos.x += x; 1.95 + cam_pos.y += y; 1.96 + cam_pos.z += z; 1.97 +} 1.98 + 1.99 +void cam_rotate(float theta, float phi) 1.100 +{ 1.101 + cam_phi += phi; 1.102 + cam_theta += theta; 1.103 +} 1.104 + 1.105 +void cam_dolly(float dist) 1.106 +{ 1.107 + cam_dist += dist; 1.108 +} 1.109 + 1.110 +void cam_inp_pan_speed(float speed) 1.111 +{ 1.112 + pan_speed = speed; 1.113 +} 1.114 + 1.115 +void cam_inp_rotate_speed(float speed) 1.116 +{ 1.117 + rot_speed = speed; 1.118 +} 1.119 + 1.120 +void cam_inp_zoom_speed(float speed) 1.121 +{ 1.122 + zoom_speed = speed; 1.123 +} 1.124 + 1.125 + 1.126 +void cam_inp_pan(int dx, int dy) 1.127 +{ 1.128 + float dxf = dx * pan_speed; 1.129 + float dyf = dy * pan_speed; 1.130 + float angle = -DEG_TO_RAD(cam_theta); 1.131 + 1.132 + cam_pos.x += cos(angle) * dxf + sin(angle) * dyf; 1.133 + cam_pos.z += -sin(angle) * dxf + cos(angle) * dyf; 1.134 +} 1.135 + 1.136 +void cam_inp_height(int dh) 1.137 +{ 1.138 + cam_pos.y += dh * pan_speed; 1.139 +} 1.140 + 1.141 +void cam_inp_rotate(int dx, int dy) 1.142 +{ 1.143 + cam_theta += dx * rot_speed; 1.144 + cam_phi += dy * rot_speed; 1.145 + 1.146 + if(cam_phi < vmin_deg) cam_phi = vmin_deg; 1.147 + if(cam_phi > vmax_deg) cam_phi = vmax_deg; 1.148 +} 1.149 + 1.150 +void cam_inp_zoom(int dz) 1.151 +{ 1.152 + cam_dist += dz * zoom_speed; 1.153 + if(cam_dist < 0.001) { 1.154 + cam_dist = 0.001; 1.155 + } 1.156 +} 1.157 + 1.158 +void cam_clip(float n, float f) 1.159 +{ 1.160 + nearclip = n; 1.161 + farclip = f; 1.162 +} 1.163 + 1.164 +void cam_fov(float f) 1.165 +{ 1.166 + vfov = f; 1.167 +} 1.168 + 1.169 +void cam_aspect(float a) 1.170 +{ 1.171 + aspect = a; 1.172 +} 1.173 + 1.174 +void cam_separation(float s) 1.175 +{ 1.176 + eye_sep = s; 1.177 +} 1.178 + 1.179 +void cam_focus_dist(float d) 1.180 +{ 1.181 + focus_dist = d; 1.182 + 1.183 + cam_separation(d / 30.0); 1.184 +} 1.185 + 1.186 +void cam_view_matrix(void) 1.187 +{ 1.188 + cam_stereo_view_matrix(CAM_CENTER); 1.189 +} 1.190 + 1.191 +void cam_stereo_view_matrix(int eye) 1.192 +{ 1.193 + static const float offs_sign[] = {0.0f, 0.5f, -0.5f}; /* center, left, right */ 1.194 + float offs = eye_sep * offs_sign[eye]; 1.195 + 1.196 + glTranslatef(offs, 0, 0); 1.197 + 1.198 + glTranslatef(0, 0, -cam_dist); 1.199 + glRotatef(cam_phi, 1, 0, 0); 1.200 + glRotatef(cam_theta, 0, 1, 0); 1.201 + glTranslatef(-cam_pos.x, -cam_pos.y, -cam_pos.z); 1.202 +} 1.203 + 1.204 +void cam_proj_matrix(void) 1.205 +{ 1.206 + cam_stereo_proj_matrix(CAM_CENTER); 1.207 +} 1.208 + 1.209 +void cam_stereo_proj_matrix(int eye) 1.210 +{ 1.211 + float vfov_rad = M_PI * vfov / 180.0; 1.212 + float top = nearclip * tan(vfov_rad * 0.5); 1.213 + float right = top * aspect; 1.214 + 1.215 + static const float offs_sign[] = {0.0f, 1.0, -1.0}; /* center, left, right */ 1.216 + float frust_shift = offs_sign[eye] * (eye_sep * 0.5 * nearclip / focus_dist); 1.217 + 1.218 + glFrustum(-right + frust_shift, right + frust_shift, -top, top, nearclip, farclip); 1.219 +}