oculus1

changeset 18:1b107de821c1

fixed the test to work with non-pow2 textures
author John Tsiombikas <nuclear@member.fsf.org>
date Thu, 26 Sep 2013 10:33:08 +0300 (2013-09-26)
parents cfe4979ab3eb
children 899cf9ebffb4 0c76f70fb7e9
files sdr/sdr.glsl src/main.cc src/vr.cc src/vr.h
diffstat 4 files changed, 118 insertions(+), 24 deletions(-) [+]
line diff
     1.1 --- a/sdr/sdr.glsl	Sat Sep 21 07:09:48 2013 +0300
     1.2 +++ b/sdr/sdr.glsl	Thu Sep 26 10:33:08 2013 +0300
     1.3 @@ -2,6 +2,7 @@
     1.4  uniform float aspect, scale;
     1.5  uniform float lens_center_offset;
     1.6  uniform vec4 dist_factors;
     1.7 +uniform vec2 tex_scale;
     1.8  
     1.9  vec2 distort_texcoords(in vec2 tc);
    1.10  float barrel_scale(float x, in vec4 k);
    1.11 @@ -10,9 +11,9 @@
    1.12  {
    1.13  	vec2 tc = distort_texcoords(gl_TexCoord[0].xy);
    1.14  
    1.15 -	float vis = any(greaterThan(tc, vec2(1.0)) || lessThan(tc, vec2(0.0))) ? 0.0 : 1.0;
    1.16 +	float vis = any(greaterThan(tc, vec2(1.0))) || any(lessThan(tc, vec2(0.0))) ? 0.0 : 1.0;
    1.17  
    1.18 -	gl_FragColor.rgb = texture2D(tex, tc).rgb * vis;
    1.19 +	gl_FragColor.rgb = texture2D(tex, tc * tex_scale).rgb * vis;
    1.20  	gl_FragColor.a = 1.0;
    1.21  }
    1.22  
     2.1 --- a/src/main.cc	Sat Sep 21 07:09:48 2013 +0300
     2.2 +++ b/src/main.cc	Thu Sep 26 10:33:08 2013 +0300
     2.3 @@ -7,6 +7,12 @@
     2.4  #include "camera.h"
     2.5  #include "sdr.h"
     2.6  
     2.7 +#ifdef __APPLE__
     2.8 +#include <OpenGL/OpenGL.h>
     2.9 +#include <OpenGL/CGLCurrent.h>
    2.10 +#include <ApplicationServices/ApplicationServices.h>
    2.11 +#endif
    2.12 +
    2.13  static bool init();
    2.14  static void cleanup();
    2.15  static void disp();
    2.16 @@ -26,6 +32,8 @@
    2.17  static void passive(int x, int y);
    2.18  static void sball_rotate(int rx, int ry, int rz);
    2.19  static bool parse_args(int argc, char **argv);
    2.20 +static void printfps();
    2.21 +static int next_pow2(int x);
    2.22  
    2.23  static VRFpsCamera cam;
    2.24  static int width, height;
    2.25 @@ -33,13 +41,15 @@
    2.26  
    2.27  static bool keystate[256];
    2.28  
    2.29 -static int rtarg_width, rtarg_height;
    2.30 +static int rtarg_width, rtarg_height, rtarg_tex_width, rtarg_tex_height;
    2.31 +static float tex_scale_x, tex_scale_y;
    2.32  static unsigned int fbo, tex[2], zbuf;
    2.33  
    2.34  static unsigned int teapot_sdr;
    2.35  
    2.36  static bool fullscreen_pending;
    2.37  
    2.38 +
    2.39  int main(int argc, char **argv)
    2.40  {
    2.41  	glutInitWindowSize(1280, 800);
    2.42 @@ -102,7 +112,12 @@
    2.43  		rtarg_width = (xsz + xsz / 2) / 2;
    2.44  		rtarg_height = ysz + ysz / 2;
    2.45  
    2.46 -		printf("render target: %dx%d\n", rtarg_width, rtarg_height);
    2.47 +		rtarg_tex_width = next_pow2(rtarg_width);
    2.48 +		rtarg_tex_height = next_pow2(rtarg_height);
    2.49 +		tex_scale_x = (float)rtarg_width / (float)rtarg_tex_width;
    2.50 +		tex_scale_y = (float)rtarg_height / (float)rtarg_tex_height;
    2.51 +
    2.52 +		printf("render target: %dx%d (%dx%d)\n", rtarg_width, rtarg_height, rtarg_tex_width, rtarg_tex_height);
    2.53  
    2.54  		// create render targets for each eye
    2.55  		GLenum wrap_mode = GL_CLAMP_TO_EDGE;
    2.56 @@ -117,31 +132,43 @@
    2.57  			glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
    2.58  			glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, wrap_mode);
    2.59  			glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, wrap_mode);
    2.60 -			glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, rtarg_width, rtarg_height, 0, GL_RGB, GL_UNSIGNED_BYTE, 0);
    2.61 +			glTexImage2D(GL_TEXTURE_2D, 0, GL_RGB, rtarg_tex_width, rtarg_tex_height, 0, GL_RGB, GL_UNSIGNED_BYTE, 0);
    2.62  		}
    2.63  
    2.64  		// create the depth render buffer
    2.65 -		glGenRenderbuffers(1, &zbuf);
    2.66 -		glBindRenderbuffer(GL_RENDERBUFFER, zbuf);
    2.67 -		glRenderbufferStorage(GL_RENDERBUFFER, GL_DEPTH_COMPONENT24, rtarg_width, rtarg_height);
    2.68 +		glGenRenderbuffersEXT(1, &zbuf);
    2.69 +		glBindRenderbufferEXT(GL_RENDERBUFFER, zbuf);
    2.70 +		glRenderbufferStorageEXT(GL_RENDERBUFFER, GL_DEPTH_COMPONENT24, rtarg_tex_width, rtarg_tex_height);
    2.71  
    2.72  		// create the FBO
    2.73 -		glGenFramebuffers(1, &fbo);
    2.74 -		glBindFramebuffer(GL_FRAMEBUFFER, fbo);
    2.75 -		glFramebufferTexture(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, tex[0], 0);
    2.76 -		glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, zbuf);
    2.77 +		glGenFramebuffersEXT(1, &fbo);
    2.78 +		glBindFramebufferEXT(GL_FRAMEBUFFER, fbo);
    2.79 +		glFramebufferTextureEXT(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, tex[0], 0);
    2.80 +		glFramebufferRenderbufferEXT(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, zbuf);
    2.81  	}
    2.82  
    2.83  	teapot_sdr = create_program_load("sdr/phong.v.glsl", "sdr/phong.p.glsl");
    2.84  
    2.85 +	// enable vsync
    2.86 +#ifdef __APPLE__
    2.87 +	int swapint = 1;
    2.88 +	CGLContextObj ctx = CGLGetCurrentContext();
    2.89 +	CGLSetParameter(ctx, kCGLCPSwapInterval, &swapint);
    2.90 +#endif
    2.91 +
    2.92 +#ifdef __APPLE__
    2.93 +	// this is required for glutWarpPointer to work correctly, otherwise after every
    2.94 +	// warp, mac os x freezes event processing for 1/4 second.
    2.95 +	CGSetLocalEventsSuppressionInterval(0.0);
    2.96 +#endif
    2.97  	return true;
    2.98  }
    2.99  
   2.100  static void cleanup()
   2.101  {
   2.102  	glDeleteTextures(2, tex);
   2.103 -	glDeleteRenderbuffers(1, &zbuf);
   2.104 -	glDeleteFramebuffers(1, &fbo);
   2.105 +	glDeleteRenderbuffersEXT(1, &zbuf);
   2.106 +	glDeleteFramebuffersEXT(1, &fbo);
   2.107  	vr_shutdown();
   2.108  }
   2.109  
   2.110 @@ -189,6 +216,8 @@
   2.111  
   2.112  	glutSwapBuffers();
   2.113  	assert(glGetError() == GL_NO_ERROR);
   2.114 +
   2.115 +	printfps();
   2.116  }
   2.117  
   2.118  // display function used in VR mode
   2.119 @@ -211,8 +240,8 @@
   2.120  	glClearColor(0.1, 0.1, 0.1, 1.0);
   2.121  
   2.122  	// draw left view
   2.123 -	glBindFramebuffer(GL_FRAMEBUFFER, fbo);
   2.124 -	glFramebufferTexture(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, tex[0], 0);
   2.125 +	glBindFramebufferEXT(GL_FRAMEBUFFER, fbo);
   2.126 +	glFramebufferTextureEXT(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, tex[0], 0);
   2.127  
   2.128  	glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
   2.129  
   2.130 @@ -228,8 +257,8 @@
   2.131  
   2.132  
   2.133  	// draw right view
   2.134 -	glBindFramebuffer(GL_FRAMEBUFFER, fbo);
   2.135 -	glFramebufferTexture(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, tex[1], 0);
   2.136 +	glBindFramebufferEXT(GL_FRAMEBUFFER, fbo);
   2.137 +	glFramebufferTextureEXT(GL_FRAMEBUFFER, GL_COLOR_ATTACHMENT0, tex[1], 0);
   2.138  
   2.139  	glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
   2.140  
   2.141 @@ -250,13 +279,15 @@
   2.142  	glClearColor(0, 0, 0, 0);
   2.143  	glClear(GL_COLOR_BUFFER_BIT);
   2.144  
   2.145 -	vr_draw_eye(tex[0], VR_EYE_LEFT);
   2.146 -	vr_draw_eye(tex[1], VR_EYE_RIGHT);
   2.147 +	vr_draw_eye(VR_EYE_LEFT, tex[0], tex_scale_x, tex_scale_y);
   2.148 +	vr_draw_eye(VR_EYE_RIGHT, tex[1], tex_scale_x, tex_scale_y);
   2.149  
   2.150  	glutSwapBuffers();
   2.151  	assert(glGetError() == GL_NO_ERROR);
   2.152  
   2.153  	glFinish();
   2.154 +
   2.155 +	printfps();
   2.156  }
   2.157  
   2.158  static void draw_scene()
   2.159 @@ -473,6 +504,21 @@
   2.160  	if(!use_vr) {
   2.161  		rtarg_width = width;
   2.162  		rtarg_height = height;
   2.163 +
   2.164 +		int new_tex_width = next_pow2(width);
   2.165 +		int new_tex_height = next_pow2(height);
   2.166 +
   2.167 +		if(new_tex_width != rtarg_tex_width || new_tex_height != rtarg_tex_width) {
   2.168 +			// TODO
   2.169 +			exit(1);
   2.170 +		}
   2.171 +
   2.172 +		rtarg_tex_width = new_tex_width;
   2.173 +		rtarg_tex_height = new_tex_height;
   2.174 +
   2.175 +		tex_scale_x = (float)rtarg_width / (float)rtarg_tex_width;
   2.176 +		tex_scale_y = (float)rtarg_height / (float)rtarg_tex_height;
   2.177 +
   2.178  	}
   2.179  }
   2.180  
   2.181 @@ -526,7 +572,7 @@
   2.182  	int center_y = height / 2;
   2.183  
   2.184  	int dx = x - center_x;
   2.185 -	int dy = y - center_y;
   2.186 +	int dy = use_vr ? 0 : y - center_y;
   2.187  
   2.188  	if(!dx && !dy) {
   2.189  		return;
   2.190 @@ -537,8 +583,8 @@
   2.191  
   2.192  	cam.input_rotate(DEG_TO_RAD(dtheta_deg), DEG_TO_RAD(dphi_deg), 0);
   2.193  
   2.194 +	glutWarpPointer(center_x, center_y);
   2.195  	glutPostRedisplay();
   2.196 -	glutWarpPointer(center_x, center_y);
   2.197  }
   2.198  
   2.199  static void sball_rotate(int rx, int ry, int rz)
   2.200 @@ -564,3 +610,33 @@
   2.201  	}
   2.202  	return true;
   2.203  }
   2.204 +
   2.205 +static void printfps()
   2.206 +{
   2.207 +	static unsigned int last_upd, frames;
   2.208 +	unsigned int msec = glutGet(GLUT_ELAPSED_TIME);
   2.209 +	unsigned int dmsec = msec - last_upd;
   2.210 +
   2.211 +	frames++;
   2.212 +
   2.213 +	if(dmsec > 2000) {
   2.214 +		float dt = (float)dmsec / 1000.0f;
   2.215 +
   2.216 +		printf("fps: %.2f        \r", (float)frames / dt);
   2.217 +		fflush(stdout);
   2.218 +
   2.219 +		frames = 0;
   2.220 +		last_upd = msec;
   2.221 +	}
   2.222 +}
   2.223 +
   2.224 +static int next_pow2(int x)
   2.225 +{
   2.226 +	x--;
   2.227 +	x = (x >> 1) | x;
   2.228 +	x = (x >> 2) | x;
   2.229 +	x = (x >> 4) | x;
   2.230 +	x = (x >> 8) | x;
   2.231 +	x = (x >> 16) | x;
   2.232 +	return x + 1;
   2.233 +}
     3.1 --- a/src/vr.cc	Sat Sep 21 07:09:48 2013 +0300
     3.2 +++ b/src/vr.cc	Thu Sep 26 10:33:08 2013 +0300
     3.3 @@ -4,6 +4,7 @@
     3.4  #include "vr_impl.h"
     3.5  #include "vr_sdr.h"
     3.6  
     3.7 +static void init_ctx();
     3.8  static bool init_ovr();
     3.9  static bool init_sdr();
    3.10  
    3.11 @@ -14,6 +15,8 @@
    3.12  {
    3.13  	glewInit();
    3.14  
    3.15 +	init_ctx();
    3.16 +
    3.17  	if(!init_ovr()) {
    3.18  		return -1;
    3.19  	}
    3.20 @@ -31,6 +34,16 @@
    3.21  	//System::Destroy();
    3.22  }
    3.23  
    3.24 +static void init_ctx()
    3.25 +{
    3.26 +	vr_ctx.info.width = 1280;
    3.27 +	vr_ctx.info.height = 800;
    3.28 +	vr_ctx.info.fov = M_PI / 2.0;
    3.29 +	vr_ctx.info.aspect = (float)vr_ctx.info.width / (float)vr_ctx.info.height;
    3.30 +	vr_ctx.info.ipd = 0.035;
    3.31 +	vr_ctx.info.scale = 1.0;
    3.32 +}
    3.33 +
    3.34  static bool init_ovr()
    3.35  {
    3.36  	LogMaskConstants log_level = LogMask_All;
    3.37 @@ -312,7 +325,7 @@
    3.38  	oq.GetEulerAngles<Axis_Y, Axis_X, Axis_Z>(euler + 1, euler, euler + 2);
    3.39  }
    3.40  
    3.41 -extern "C" void vr_draw_eye(unsigned int tex, int eye)
    3.42 +extern "C" void vr_draw_eye(int eye, unsigned int tex, float tex_scale_x, float tex_scale_y)
    3.43  {
    3.44  	static const float rects[3][4] = {
    3.45  		{-1, -1, 1, 1},
    3.46 @@ -342,6 +355,10 @@
    3.47  			float offset = vr_ctx.info.lens_center_offset * offs_scale[eye];
    3.48  			glUniform1f(loc, offset);
    3.49  		}
    3.50 +
    3.51 +		if((loc = glGetUniformLocation(sdrprog, "tex_scale")) != -1) {
    3.52 +			glUniform2f(loc, tex_scale_x, tex_scale_y);
    3.53 +		}
    3.54  	}
    3.55  
    3.56  	glBindTexture(GL_TEXTURE_2D, tex);
     4.1 --- a/src/vr.h	Sat Sep 21 07:09:48 2013 +0300
     4.2 +++ b/src/vr.h	Thu Sep 26 10:33:08 2013 +0300
     4.3 @@ -54,7 +54,7 @@
     4.4  void vr_get_rotation_euler(float *euler);
     4.5  
     4.6  /* OpenGL stuff */
     4.7 -void vr_draw_eye(unsigned int tex, int eye);
     4.8 +void vr_draw_eye(int eye, unsigned int tex, float tex_scale_x, float tex_scale_y);
     4.9  
    4.10  #ifdef __cplusplus
    4.11  }