Fixed OpenGL checks (#if HAVE_GL, not #ifdef...), plus added message

that OpenGL is required...


git-svn-id: file:///fltk/svn/fltk/trunk@369 ea41ed52-d2ee-0310-a9c1-e6b18d33e121
This commit is contained in:
Michael R Sweet 1999-03-04 20:26:00 +00:00
parent 474e82bd95
commit 9ae933d004
2 changed files with 30 additions and 11 deletions

View File

@ -1,5 +1,5 @@
// //
// "$Id: CubeView.cxx,v 1.2 1999/03/04 20:11:48 mike Exp $" // "$Id: CubeView.cxx,v 1.3 1999/03/04 20:26:00 mike Exp $"
// //
// CubeView class implementation for the Fast Light Tool Kit (FLTK). // CubeView class implementation for the Fast Light Tool Kit (FLTK).
// //
@ -27,8 +27,13 @@
#include <math.h> #include <math.h>
#if HAVE_GL
CubeView::CubeView(int x,int y,int w,int h,const char *l) CubeView::CubeView(int x,int y,int w,int h,const char *l)
: Fl_Gl_Window(x,y,w,h,l) : Fl_Gl_Window(x,y,w,h,l)
#else
CubeView::CubeView(int x,int y,int w,int h,const char *l)
: Fl_Box(x,y,w,h,l)
#endif /* HAVE_GL */
{ {
vAng = 0.0; vAng = 0.0;
hAng=0.0; hAng=0.0;
@ -45,13 +50,18 @@ CubeView::CubeView(int x,int y,int w,int h,const char *l)
boxv5[0] = 0.5; boxv5[1] = -0.5; boxv5[2] = 0.5; boxv5[0] = 0.5; boxv5[1] = -0.5; boxv5[2] = 0.5;
boxv6[0] = 0.5; boxv6[1] = 0.5; boxv6[2] = 0.5; boxv6[0] = 0.5; boxv6[1] = 0.5; boxv6[2] = 0.5;
boxv7[0] = -0.5; boxv7[1] = 0.5; boxv7[2] = 0.5; boxv7[0] = -0.5; boxv7[1] = 0.5; boxv7[2] = 0.5;
#if !HAVE_GL
label("OpenGL is required for this demo to operate.");
align(FL_ALIGN_WRAP | FL_ALIGN_INSIDE);
#endif /* !HAVE_GL */
}; };
// The color used for the edges of the bounding cube. // The color used for the edges of the bounding cube.
#define CUBECOLOR 255,255,255,255 #define CUBECOLOR 255,255,255,255
#if HAVE_GL
void CubeView::drawCube() { void CubeView::drawCube() {
#ifdef HAVE_GL
/* Draw a colored cube */ /* Draw a colored cube */
glBegin(GL_LINE_LOOP); glColor4ub(CUBECOLOR); v3f(boxv0); v3f(boxv1); v3f(boxv2); v3f(boxv3); glEnd(); glBegin(GL_LINE_LOOP); glColor4ub(CUBECOLOR); v3f(boxv0); v3f(boxv1); v3f(boxv2); v3f(boxv3); glEnd();
glBegin(GL_LINE_LOOP); glColor4ub(CUBECOLOR); v3f(boxv5); v3f(boxv4); v3f(boxv7); v3f(boxv6); glEnd(); glBegin(GL_LINE_LOOP); glColor4ub(CUBECOLOR); v3f(boxv5); v3f(boxv4); v3f(boxv7); v3f(boxv6); glEnd();
@ -66,11 +76,9 @@ void CubeView::drawCube() {
glBegin(GL_QUADS); glColor4ub(255, 0, 0, ALPHA); v3f(boxv4); v3f(boxv5); v3f(boxv6); v3f(boxv7); glEnd(); glBegin(GL_QUADS); glColor4ub(255, 0, 0, ALPHA); v3f(boxv4); v3f(boxv5); v3f(boxv6); v3f(boxv7); glEnd();
glBegin(GL_QUADS); glColor4ub(255, 0, 255, ALPHA); v3f(boxv0); v3f(boxv3); v3f(boxv7); v3f(boxv4); glEnd(); glBegin(GL_QUADS); glColor4ub(255, 0, 255, ALPHA); v3f(boxv0); v3f(boxv3); v3f(boxv7); v3f(boxv4); glEnd();
glBegin(GL_QUADS); glColor4ub( 0, 255, 0, ALPHA); v3f(boxv1); v3f(boxv5); v3f(boxv6); v3f(boxv2); glEnd(); glBegin(GL_QUADS); glColor4ub( 0, 255, 0, ALPHA); v3f(boxv1); v3f(boxv5); v3f(boxv6); v3f(boxv2); glEnd();
#endif /* HAVE_GL */
};//drawCube };//drawCube
void CubeView::draw() { void CubeView::draw() {
#ifdef HAVE_GL
if (!valid()) { if (!valid()) {
glLoadIdentity(); glLoadIdentity();
glViewport(0,0,w(),h()); glViewport(0,0,w(),h());
@ -90,9 +98,9 @@ void CubeView::draw() {
drawCube(); drawCube();
glPopMatrix(); glPopMatrix();
#endif /* HAVE_GL */
}; };
#endif /* HAVE_GL */
// //
// End of "$Id: CubeView.cxx,v 1.2 1999/03/04 20:11:48 mike Exp $". // End of "$Id: CubeView.cxx,v 1.3 1999/03/04 20:26:00 mike Exp $".
// //

View File

@ -1,5 +1,5 @@
// //
// "$Id: CubeView.h,v 1.2 1999/03/04 20:11:49 mike Exp $" // "$Id: CubeView.h,v 1.3 1999/03/04 20:26:00 mike Exp $"
// //
// CubeView class definitions for the Fast Light Tool Kit (FLTK). // CubeView class definitions for the Fast Light Tool Kit (FLTK).
// //
@ -27,10 +27,12 @@
#define CUBEVIEW_H 1 #define CUBEVIEW_H 1
#include <config.h> #include <config.h>
#include <FL/Fl.H> #include <FL/Fl.H>
#if HAVE_GL
# include <FL/Fl_Gl_Window.H> # include <FL/Fl_Gl_Window.H>
#ifdef HAVE_GL
# include <FL/gl.h> # include <FL/gl.h>
# include <GL/glu.h> # include <GL/glu.h>
#else
# include <FL/Fl_Box.H>
#endif /* HAVE_GL */ #endif /* HAVE_GL */
#include <stdlib.h> #include <stdlib.h>
@ -38,8 +40,11 @@
// shorthand to save some bits. // shorthand to save some bits.
#define v3f(x) glVertex3fv(x) #define v3f(x) glVertex3fv(x)
#if HAVE_GL
class CubeView : public Fl_Gl_Window { class CubeView : public Fl_Gl_Window {
#else
class CubeView : public Fl_Box {
#endif /* HAVE_GL */
public: public:
// this value determines the scaling factor used to draw the cube. // this value determines the scaling factor used to draw the cube.
@ -81,6 +86,7 @@ public:
*/ */
void pany(float y){yshift=y;}; void pany(float y){yshift=y;};
#if HAVE_GL
/*The widget class draw() override. /*The widget class draw() override.
* *
*The draw() function initialize Gl for another round o f drawing *The draw() function initialize Gl for another round o f drawing
@ -89,6 +95,7 @@ public:
* *
*/ */
void draw(); void draw();
#endif /* HAVE_GL */
private: private:
/* Draw the cube boundaries /* Draw the cube boundaries
@ -96,7 +103,11 @@ private:
*Draw the faces of the cube using the boxv[] vertices, using *Draw the faces of the cube using the boxv[] vertices, using
* GL_LINE_LOOP for the faces. The color is \#defined by CUBECOLOR. * GL_LINE_LOOP for the faces. The color is \#defined by CUBECOLOR.
*/ */
#if HAVE_GL
void drawCube(); void drawCube();
#else
void drawCube() { }
#endif /* HAVE_GL */
float vAng,hAng; float vAng,hAng;
float xshift,yshift; float xshift,yshift;
@ -111,5 +122,5 @@ private:
#endif #endif
// //
// End of "$Id: CubeView.h,v 1.2 1999/03/04 20:11:49 mike Exp $". // End of "$Id: CubeView.h,v 1.3 1999/03/04 20:26:00 mike Exp $".
// //