#include <limits.h>
#include <unistd.h>
#include <assert.h>
-#include <GL/gl.h>
#include <boost/program_options.hpp>
namespace po = boost::program_options;
-// include proper GL connector
+// my GL utility functions and the GL window class
+#include "glutil.h"
#include "glwindow.h"
-#if defined(USE_GLX)
+// include proper GL backend (windowing system)
+#if defined(WIN_GLX)
#include "glxbackend.h"
static GLBackend *createGLBackend()
{
return new GLXBackend();
}
-#elif defined(USE_EGL)
+#elif defined(WIN_EGL)
#include "eglbackend.h"
static GLBackend *createGLBackend()
{
return tp.tv_sec + 1e-9 * tp.tv_nsec;
}
-static void rectQuad(GLfloat x1, GLfloat y1, GLfloat x2, GLfloat y2)
-{
- glVertex2f(x1, y1);
- glVertex2f(x2, y1);
- glVertex2f(x2, y2);
- glVertex2f(x1, y2);
-}
-
// the window
class TearTestWindow : public GLWindow {
public:
- TearTestWindow(bool overdraw, bool copy, int sleep_time) : GLWindow(XOpenDisplay(0), createGLBackend()),
- overdraw(overdraw), copy(copy), sleep_time(sleep_time), boxPos(0), boxDirection(1)
+ TearTestWindow() : GLWindow(XOpenDisplay(0), createGLBackend()),
+ overdraw(false), sleep_time(0), boxPos(0), boxDirection(1)
{}
- void setSwapInterval(int i) {
- getBackend()->setSwapInterval(i);
- }
+ void setOverdraw(bool overdraw) { this->overdraw = overdraw; }
+ void setSleepTime(int sleep_time) { this->sleep_time = sleep_time; }
+
+ void setSwapInterval(int i) { getBackend()->setSwapInterval(i); }
+
+private:
+ bool overdraw;
+ int sleep_time;
+ // animation control
+ double lastFrame;
+ GLfloat boxPos, boxDirection;
+ // FPS, profiler
+ double lastDisplay, lastProfile;
+ int framect;
+ ProfilerState curState;
+ double stateTime[NumProfilerStates];
protected:
virtual void initGL()
virtual void resizeGL(unsigned int width, unsigned int height)
{
- // prevent divide-by-zero
- if (height == 0)
- height = 1;
glViewport(0, 0, width, height);
- glMatrixMode(GL_PROJECTION);
- glLoadIdentity();
- glOrtho (0, 1, 1, 0, 0, 1);
- glMatrixMode(GL_MODELVIEW);
+ initialise2dProjection();
glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
- glClear(GL_COLOR_BUFFER_BIT);
- glFlush();
}
void profilerTick(ProfilerState nextState)
profilerTick(StateClear);
if (overdraw) {
// clear manually
- glBegin(GL_QUADS);
- glColor3f(0.0f, 0.0f, 0.0f);
- rectQuad(0, 0, 1, 1);
- glEnd();
+ drawQuad(/*color*/0.0f, 0.0f, 0.0f, /*coordinates*/0, 0, 1, 1);
}
else {
glClear(GL_COLOR_BUFFER_BIT);
}
//////////////////////////////////////////////
profilerTick(StateDraw);
- glBegin(GL_QUADS);
- glColor3f(0.8f, 1.0f, 0.75f);
- rectQuad(boxPos, 0, boxPos+boxWidth, 1);
- glEnd();
+ drawQuad(/*color*/0.8f, 1.0f, 0.75f, /*coordinates*/boxPos, 0, boxPos+boxWidth, 1);
usleep(sleep_time*1000);
//////////////////////////////////////////////
profilerTick(StatePresent);
- if (copy) {
- glDrawBuffer(GL_FRONT);
- glCopyPixels(0, 0, getWidth(), getHeight(), GL_COLOR);
- glDrawBuffer(GL_BACK);
- }
- else {
- getBackend()->swapBuffers();
- }
+ getBackend()->swapBuffers();
//////////////////////////////////////////////
profilerTick(StatePostRender);
- glFlush();
+ glFinish();
++framect;
//////////////////////////////////////////////
profilerTick(StateOutsideRender);
default: break;
}
}
-
-private:
- bool overdraw, copy;
- int sleep_time;
- // animation control
- double lastFrame;
- GLfloat boxPos, boxDirection;
- // FPS, profiler
- double lastDisplay, lastProfile;
- int framect;
- ProfilerState curState;
- double stateTime[NumProfilerStates];
};
int main(int argc, char ** argv)
desc.add_options()
("help,h", "produce help message")
("swap-interval,i", po::value<int>(), "set swap interval")
- ("copy,c", "copy to front buffer (instead of performing a buffer swap)")
("overdraw,o", "overdraw previous image (instead of calling glClear)")
("sleep,s", po::value<int>()->default_value(0), "Number of milliseconds to sleap in each frame (in the drawing phase)")
;
}
// actual program
- TearTestWindow w(vm.count("overdraw"), vm.count("copy"), vm["sleep"].as<int>());
+ TearTestWindow w;
+ w.setOverdraw(vm.count("overdraw"));
+ w.setSleepTime(vm["sleep"].as<int>());
w.open(800, 600);
if (vm.count("swap-interval"))
w.setSwapInterval(vm["swap-interval"].as<int>());