]> git.treefish.org Git - phys/latlib.git/blob - culooks.cpp
...
[phys/latlib.git] / culooks.cpp
1 #include "culooks.h"
2
3 #include <vector>
4
5 #include <iostream>
6 #include <math.h>
7
8 vector< pair<int,culooks::window*> > culooks::Windows;
9 pthread_t culooks::glThreadId;
10 culooks::comarg culooks::comArg;
11
12 int culooks::windowid = 0;
13
14 using namespace std;
15
16 culooks::culooks (const char* name, const int& xcubes, const int& ycubes, const int& l, int *argc, char **argv)
17 {
18   window *Win = new window;
19   int winsize[2];
20
21   Win->layout[0] = xcubes;
22   Win->layout[1] = ycubes;
23   Win->aspect = (double)xcubes/ycubes;
24   for (int icube=0; icube<xcubes*ycubes; icube++) {
25     cube newCube(l);
26     Win->cubes.push_back(newCube);
27   }
28
29   if( Win->layout[0] >= Win->layout[1] ) {
30     winsize[0] = 640;
31     winsize[1] = (640.0/Win->layout[0])*Win->layout[1];
32   }
33   else {
34     winsize[1] = 640;
35     winsize[0] = (640.0/Win->layout[1])*Win->layout[0];
36   }
37
38   Win->w = winsize[0];
39   Win->h = winsize[1];
40
41   Win->name = name;
42
43   Win->initialized = false;
44
45   Windows.push_back( pair<int,culooks::window*>(0, Win) );
46
47   if (windowid == 0) {
48     comArg.argc = argc;
49     comArg.argv = argv;
50     pthread_create(&glThreadId, 0, &drawing::glutThread, &comArg);
51   }
52   mywid = windowid;
53   windowid++;
54 }
55
56 void culooks::setLink (const int& cubeid, const int& posdir,
57                        const float& red, const float& green, const float& blue, const float& alpha)
58 {
59   Windows[mywid].second->cubes[cubeid].setLink(posdir, red, green, blue, alpha);
60 }
61
62 void culooks::setPlaq (const int& cubeid, const int& posdir,
63                        const float& red, const float& green, const float& blue, const float& alpha)
64 {
65   Windows[mywid].second->cubes[cubeid].setPlaq(posdir, red, green, blue, alpha);
66 }
67
68 void culooks::swapBuffers () {
69   for (int icube=0; icube<Windows[mywid].second->cubes.size(); icube++) {
70     Windows[mywid].second->cubes[icube].swapLinkBuffer();
71     Windows[mywid].second->cubes[icube].swapPlaqBuffer();
72   }
73   Windows[mywid].second->redisplay = true;
74 }
75
76 void culooks::hidePlaqs (const int& cubeid) {
77   Windows[mywid].second->cubes[cubeid].hidePlaqs();
78 }
79
80 void culooks::hidePlaqs () {
81   for (int icube=0; icube<Windows[mywid].second->cubes.size(); icube++)
82     Windows[mywid].second->cubes[icube].hidePlaqs();
83 }
84
85 void culooks::hideLinks (const int& cubeid) {
86   Windows[mywid].second->cubes[cubeid].hideLinks();
87 }
88
89 void culooks::hideLinks () {
90   for (int icube=0; icube<Windows[mywid].second->cubes.size(); icube++)
91     Windows[mywid].second->cubes[icube].hideLinks();
92 }
93
94 void culooks::setBgColor(const float& red, const float& green, const float& blue, const float& alpha)
95 {
96   Windows[mywid].second->bgcolor[0] = red;
97   Windows[mywid].second->bgcolor[1] = green;
98   Windows[mywid].second->bgcolor[2] = blue;
99   Windows[mywid].second->bgcolor[3] = alpha;
100 }
101
102 void culooks::setWireColor(const float& r, const float& g, const float& b, const float& a)
103 {
104   for (int icube=0; icube<Windows[mywid].second->cubes.size(); icube++)
105     Windows[mywid].second->cubes[icube].setWireColor(r, g, b, a);
106 }