X-Git-Url: http://git.treefish.org/~alex/phys/latlib.git/blobdiff_plain/0f815d3fea69adf1ee22cff3a728a4c22cf6e466..7f5403eed95da4350dcc03d817eb8468dab07142:/culooks.h diff --git a/culooks.h b/culooks.h index 76f0919..66b3320 100644 --- a/culooks.h +++ b/culooks.h @@ -17,23 +17,65 @@ class culooks public: culooks (const char* name, const int& xcubes, const int& ycubes, const int& l, int *argc, char **argv); + void setLink (const int& cubeid, const int& posdir, + const float& red, const float& green, const float& blue, const float& alpha); + void setPlaq (const int& cubeid, const int& posdir, + const float& red, const float& green, const float& blue, const float& alpha); + void swapBuffers(); + void hidePlaqs(const int& cubeid); + void hidePlaqs(); + void hideLinks(const int& cubeid); + void hideLinks(); + void setBgColor(const float& red, const float& green, const float& blue, const float& alpha); + void setWireColor(const float& r, const float& g, const float& b, const float& a); + void setFrameWidth(float width); + void setLinkWidth(float width); private: + + struct comarg { + int *argc; + char **argv; + }; + + static comarg comArg; class cube { public: - cube(int l); + cube (int l); void draw(); int id; float az, alt; + float azRotSpeed; float zoom; + void setLink (const int& posdir, + const float& red, const float& green, const float& blue, const float& alpha); + void setPlaq (const int& posdir, + const float& red, const float& green, const float& blue, const float& alpha); + void swapLinkBuffer(); + void swapPlaqBuffer(); + void hidePlaqs(); + void hideLinks(); + void setWireColor(const float& r, const float& g, const float& b, const float& a); + void setFrameWidth(float width); + void setLinkWidth(float width); private: + float wireColor[4]; void drawAll(); void drawBox(); - static int allid; + static void drawFrame(); float *plaq; float *link; + float *plaqbuf[2]; + float *linkbuf[2]; int l; + int plaqbuf_active; + int linkbuf_active; + static int allid; + bool hideplaquettes; + bool hidelinks; + float framewidth; + float linkwidth; }; struct window { @@ -44,6 +86,8 @@ class culooks int gwinid; bool initialized; string name; + float bgcolor[4]; + bool redisplay; }; class drawing @@ -57,7 +101,7 @@ class culooks static void reshapeFunc(int w, int h); static void displayFunc(); static void initWindow(int winid); - static void idleFunc_master(); + static void idleFunc(); public: static void* glutThread(void *leer); };