istereo2

changeset 20:2b85d05df3f2

animation controls for easier screenshot grabbing
author John Tsiombikas <nuclear@member.fsf.org>
date Fri, 02 Oct 2015 04:54:55 +0300 (2015-10-02)
parents dc99ceee9294
children 8f41da60b9f5
files ios/shots/SIZES src/glut/main.c src/istereo.c src/istereo.h src/ui.cc
diffstat 5 files changed, 50 insertions(+), 10 deletions(-) [+]
line diff
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/ios/shots/SIZES	Fri Oct 02 04:54:55 2015 +0300
     1.3 @@ -0,0 +1,5 @@
     1.4 +3.5 inch: 960x640
     1.5 +4.0 inch: 1136x640
     1.6 +4.7 inch: 1334x750
     1.7 +5.5 inch: 2208x1242
     1.8 +    ipad: 2048x1496
     2.1 --- a/src/glut/main.c	Fri Oct 02 04:20:21 2015 +0300
     2.2 +++ b/src/glut/main.c	Fri Oct 02 04:54:55 2015 +0300
     2.3 @@ -93,6 +93,18 @@
     2.4  		}
     2.5  		break;
     2.6  
     2.7 +	case ' ':
     2.8 +		playpause();
     2.9 +		break;
    2.10 +
    2.11 +	case '.':
    2.12 +		seektime(250);
    2.13 +		break;
    2.14 +
    2.15 +	case ',':
    2.16 +		seektime(-250);
    2.17 +		break;
    2.18 +
    2.19  	default:
    2.20  		break;
    2.21  	}
     3.1 --- a/src/istereo.c	Fri Oct 02 04:20:21 2015 +0300
     3.2 +++ b/src/istereo.c	Fri Oct 02 04:54:55 2015 +0300
     3.3 @@ -51,6 +51,9 @@
     3.4  int view_xsz, view_ysz;
     3.5  float view_aspect;
     3.6  
     3.7 +static int paused;
     3.8 +static long sys_msec, time_offset, time_msec, last_pause;
     3.9 +
    3.10  int stereo = 0;
    3.11  int use_bump = 0;
    3.12  int show_opt = 1;
    3.13 @@ -138,7 +141,9 @@
    3.14  void redraw(void)
    3.15  {
    3.16  	float pan_x, pan_y, z;
    3.17 -	float tsec = get_time_sec();
    3.18 +	sys_msec = get_time_msec();
    3.19 +	time_msec = (paused ? last_pause : sys_msec) + time_offset;
    3.20 +	double tsec = time_msec / 1000.0;
    3.21  
    3.22  	z = ring_height * segm;
    3.23  	worm(tsec, z, &pan_x, &pan_y);
    3.24 @@ -433,6 +438,21 @@
    3.25  	}
    3.26  }
    3.27  
    3.28 +void playpause(void)
    3.29 +{
    3.30 +	paused = !paused;
    3.31 +	if(paused) {
    3.32 +		last_pause = sys_msec;
    3.33 +	} else {
    3.34 +		time_offset -= sys_msec - last_pause;
    3.35 +	}
    3.36 +}
    3.37 +
    3.38 +void seektime(long msec)
    3.39 +{
    3.40 +	time_offset -= msec;
    3.41 +}
    3.42 +
    3.43  static unsigned int get_shader_program(const char *vfile, const char *pfile)
    3.44  {
    3.45  	unsigned int prog, vs, ps;
     4.1 --- a/src/istereo.h	Fri Oct 02 04:20:21 2015 +0300
     4.2 +++ b/src/istereo.h	Fri Oct 02 04:54:55 2015 +0300
     4.3 @@ -27,4 +27,7 @@
     4.4  void mouse_button(int bn, int press, int x, int y);
     4.5  void mouse_motion(int x, int y);
     4.6  
     4.7 +void playpause(void);
     4.8 +void seektime(long msec);
     4.9 +
    4.10  #endif	/* ISTEREO_H_ */
     5.1 --- a/src/ui.cc	Fri Oct 02 04:20:21 2015 +0300
     5.2 +++ b/src/ui.cc	Fri Oct 02 04:54:55 2015 +0300
     5.3 @@ -43,21 +43,21 @@
     5.4  
     5.5  	CheckBox *cbox;
     5.6  
     5.7 -#ifdef IPHONE
     5.8 -	if(have_retina()) {
     5.9 +//#ifdef IPHONE
    5.10 +//	if(have_retina()) {
    5.11  		cbox = new CheckBox;
    5.12  		cbox->set_position(300, ypos + vsep);
    5.13  		cbox->set_size(300, vsz);
    5.14  		cbox->set_text("Retina quality rendering");
    5.15 -		if(using_retina_res()) {
    5.16 +		//if(using_retina_res()) {
    5.17  			cbox->check();
    5.18 -		} else {
    5.19 -			cbox->uncheck();
    5.20 -		}
    5.21 -		cbox->set_callback(EV_CHANGE, retina_cbox_handler);
    5.22 +		//} else {
    5.23 +		//	cbox->uncheck();
    5.24 +		//}
    5.25 +//		cbox->set_callback(EV_CHANGE, retina_cbox_handler);
    5.26  		scr.add_widget(cbox);
    5.27 -	}
    5.28 -#endif
    5.29 +//	}
    5.30 +//#endif
    5.31  
    5.32  	cbox = new CheckBox;
    5.33  	cbox->set_position(300, ypos);