00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #include <QtOpenGL>
00029 #define BYTE unsigned char
00030
00031 namespace Enki
00032 {
00033
00034
00035
00036
00037
00038 static BYTE face_indicies[70][9] = {
00039
00040 {28,18,30 ,0,0,0 ,0,1,2 }, {47,18,28 ,0,0,0 ,3,1,0 }, {47,20,18 ,0,0,0 ,3,4,1 },
00041 {45,20,47 ,0,0,0 ,5,4,3 }, {45,11,20 ,0,0,0 ,5,6,4 }, {44,11,45 ,0,0,0 ,7,6,5 },
00042 {44,13,11 ,0,0,0 ,7,8,6 }, {41,13,44 ,0,0,0 ,9,8,7 }, {41,7,13 ,0,0,0 ,9,10,8 },
00043 {39,7,41 ,0,0,0 ,11,10,9 }, {39,9,7 ,0,0,0 ,11,12,10 }, {37,9,39 ,0,0,0 ,13,12,11 },
00044 {37,2,9 ,0,0,0 ,13,14,12 }, {35,2,37 ,0,0,0 ,15,14,13 }, {2,35,3 ,0,0,0 ,14,15,16 },
00045 {3,35,0 ,0,0,0 ,16,15,17 }, {35,33,0 ,0,0,0 ,15,18,17 }, {0,33,14 ,0,0,0 ,17,18,19 },
00046 {33,32,14 ,0,0,0 ,18,20,19 }, {14,32,16 ,0,0,0 ,19,20,21 }, {24,16,32 ,0,0,0 ,22,21,20 },
00047 {22,16,24 ,0,0,0 ,23,21,22 }, {4,3,5 ,1,2,3 ,24,25,26 }, {4,2,3 ,1,4,2 ,24,27,25 },
00048 {10,2,4 ,5,4,1 ,28,27,24 }, {10,9,2 ,5,6,4 ,28,29,27 }, {8,9,10 ,7,6,5 ,30,29,28 },
00049 {8,7,9 ,7,8,6 ,30,31,29 }, {6,7,8 ,9,8,7 ,32,31,30 }, {6,13,7 ,9,10,8 ,32,33,31 },
00050 {12,13,6 ,11,10,9 ,34,33,32 }, {12,11,13 ,11,12,10 ,34,35,33 },
00051 {21,11,12 ,13,12,11 ,36,35,34 }, {21,20,11 ,13,14,12 ,36,37,35 },
00052 {19,20,21 ,15,14,13 ,38,37,36 }, {19,18,20 ,15,16,14 ,38,39,37 },
00053 {31,18,19 ,17,16,15 ,40,39,38 }, {31,30,18 ,17,18,16 ,40,41,39 },
00054 {29,30,31 ,19,18,17 ,42,43,44 }, {29,28,30 ,19,20,18 ,42,45,43 },
00055 {27,28,29 ,21,20,19 ,46,45,42 }, {27,47,28 ,21,22,20 ,46,47,45 },
00056 {46,47,27 ,23,22,21 ,48,47,46 }, {46,45,47 ,23,24,22 ,48,49,47 },
00057 {43,45,46 ,25,24,23 ,50,49,48 }, {43,44,45 ,25,26,24 ,50,51,49 },
00058 {42,44,43 ,27,26,25 ,52,51,50 }, {42,41,44 ,27,28,26 ,52,53,51 },
00059 {40,41,42 ,29,28,27 ,54,53,52 }, {40,39,41 ,29,30,28 ,54,55,53 },
00060 {38,39,40 ,31,30,29 ,56,55,54 }, {38,37,39 ,31,32,30 ,56,57,55 },
00061 {36,37,38 ,33,32,31 ,58,57,56 }, {36,35,37 ,33,34,32 ,58,59,57 },
00062 {34,35,36 ,35,34,33 ,60,59,58 }, {34,33,35 ,35,36,34 ,60,61,59 },
00063 {26,33,34 ,37,36,35 ,62,61,60 }, {26,32,33 ,37,38,36 ,62,63,61 },
00064 {25,32,26 ,39,38,37 ,64,63,62 }, {25,24,32 ,39,40,38 ,64,65,63 },
00065 {23,24,25 ,41,40,39 ,66,65,64 }, {23,22,24 ,41,42,40 ,66,67,65 },
00066 {17,22,23 ,43,42,41 ,68,67,66 }, {17,16,22 ,43,44,42 ,68,69,67 },
00067 {15,16,17 ,45,44,43 ,70,69,68 }, {15,14,16 ,45,46,44 ,70,71,69 },
00068 {1,14,15 ,47,46,45 ,72,71,70 }, {1,0,14 ,47,48,46 ,72,73,71 },
00069 {5,0,1 ,3,48,47 ,26,73,72 }, {5,3,0 ,3,2,48 ,26,25,73 }
00070 };
00071 static GLfloat vertices [48][3] = {
00072 {0.0155634f,0.0155634f,0.09225f},{0.0150897f,0.0150897f,0.0835f},{0.00569661f,0.02126f,0.09225f},
00073 {0.011005f,0.0190612f,0.09225f},{0.0055232f,0.0206129f,0.0835f},{0.01067f,0.018481f,0.0835f},
00074 {-0.01067f,0.018481f,0.0835f},{-0.00569661f,0.02126f,0.09225f},{-0.0055232f,0.0206129f,0.0835f},
00075 {0.0f,0.02201f,0.09225f},{0.0f,0.02134f,0.0835f},{-0.0155634f,0.0155634f,0.09225f},
00076 {-0.0150897f,0.0150897f,0.0835f},{-0.011005f,0.0190612f,0.09225f},{0.0190612f,0.011005f,0.09225f},
00077 {0.018481f,0.01067f,0.0835f},{0.02126f,0.00569661f,0.09225f},{0.0206129f,0.0055232f,0.0835f},
00078 {-0.02126f,0.00569661f,0.09225f},{-0.0206129f,0.0055232f,0.0835f},{-0.0190612f,0.011005f,0.09225f},
00079 {-0.018481f,0.01067f,0.0835f},{0.02201f,0.0f,0.09225f},{0.02134f,0.0f,0.0835f},
00080 {0.02126f,-0.00569661f,0.09225f},{0.0206129f,-0.0055232f,0.0835f},{0.018481f,-0.01067f,0.0835f},
00081 {-0.018481f,-0.01067f,0.0835f},{-0.02126f,-0.00569661f,0.09225f},{-0.0206129f,-0.0055232f,0.0835f},
00082 {-0.02201f,0.0f,0.09225f},{-0.02134f,0.0f,0.0835f},{0.0190612f,-0.011005f,0.09225f},
00083 {0.0155634f,-0.0155634f,0.09225f},{0.0150897f,-0.0150897f,0.0835f},{0.011005f,-0.0190612f,0.09225f},
00084 {0.01067f,-0.018481f,0.0835f},{0.00569661f,-0.02126f,0.09225f},{0.0055232f,-0.0206129f,0.0835f},
00085 {0.0f,-0.02201f,0.09225f},{0.0f,-0.02134f,0.0835f},{-0.00569661f,-0.02126f,0.09225f},
00086 {-0.0055232f,-0.0206129f,0.0835f},{-0.01067f,-0.018481f,0.0835f},{-0.011005f,-0.0190612f,0.09225f},
00087 {-0.0155634f,-0.0155634f,0.09225f},{-0.0150897f,-0.0150897f,0.0835f},{-0.0190612f,-0.011005f,0.09225f}
00088 };
00089 static GLfloat normals [49][3] = {
00090 {0.0f,0.0f,1.0f},{0.300042f,0.950872f,-0.076275f},{0.460206f,0.884529f,-0.0762749f},
00091 {0.535922f,0.840815f,-0.0762749f},{0.215592f,0.9735f,-0.076275f},{0.0437144f,0.996128f,-0.076275f},
00092 {-0.0437144f,0.996128f,-0.076275f},{-0.215592f,0.9735f,-0.076275f},{-0.300042f,0.950872f,-0.076275f},
00093 {-0.460206f,0.884529f,-0.0762749f},{-0.535922f,0.840815f,-0.0762749f},{-0.673458f,0.735279f,-0.0762749f},
00094 {-0.73528f,0.673458f,-0.0762749f},{-0.840815f,0.535922f,-0.0762749f},{-0.884529f,0.460206f,-0.0762749f},
00095 {-0.950872f,0.300042f,-0.076275f},{-0.9735f,0.215592f,-0.076275f},{-0.996128f,0.0437144f,-0.076275f},
00096 {-0.996128f,-0.0437144f,-0.076275f},{-0.9735f,-0.215592f,-0.076275f},{-0.950872f,-0.300042f,-0.076275f},
00097 {-0.884529f,-0.460206f,-0.0762749f},{-0.840815f,-0.535922f,-0.0762749f},{-0.735279f,-0.673458f,-0.0762749f},
00098 {-0.673458f,-0.73528f,-0.0762749f},{-0.535922f,-0.840815f,-0.0762749f},{-0.460206f,-0.884529f,-0.0762749f},
00099 {-0.300042f,-0.950872f,-0.076275f},{-0.215592f,-0.9735f,-0.076275f},{-0.0437144f,-0.996128f,-0.076275f},
00100 {0.0437144f,-0.996128f,-0.076275f},{0.215592f,-0.9735f,-0.076275f},{0.300042f,-0.950872f,-0.076275f},
00101 {0.460206f,-0.884529f,-0.0762749f},{0.535922f,-0.840815f,-0.0762749f},{0.673458f,-0.735279f,-0.0762749f},
00102 {0.73528f,-0.673458f,-0.0762749f},{0.840815f,-0.535922f,-0.0762749f},{0.884529f,-0.460206f,-0.0762749f},
00103 {0.950872f,-0.300042f,-0.076275f},{0.9735f,-0.215592f,-0.076275f},{0.996128f,-0.0437144f,-0.076275f},
00104 {0.996128f,0.0437144f,-0.076275f},{0.9735f,0.215592f,-0.076275f},{0.950872f,0.300042f,-0.076275f},
00105 {0.884529f,0.460206f,-0.0762749f},{0.840815f,0.535922f,-0.0762749f},{0.735279f,0.673458f,-0.0762749f},
00106 {0.673458f,0.73528f,-0.0762749f}
00107 };
00108 static GLfloat textures [74][2] = {
00109 {0.510277f,0.111667f},{0.510277f,0.130689f},{0.509025f,0.121178f},
00110 {0.513948f,0.102804f},{0.513948f,0.139551f},{0.519788f,0.0951934f},
00111 {0.519788f,0.147162f},{0.527399f,0.0893536f},{0.527399f,0.153002f},
00112 {0.536261f,0.0856825f},{0.536261f,0.156673f},{0.545772f,0.0844303f},
00113 {0.545772f,0.157925f},{0.555283f,0.0856825f},{0.555283f,0.156673f},
00114 {0.564146f,0.0893536f},{0.564146f,0.153002f},{0.571757f,0.147162f},
00115 {0.571757f,0.0951934f},{0.577597f,0.139551f},{0.577597f,0.102804f},
00116 {0.581268f,0.130689f},{0.581268f,0.111667f},{0.58252f,0.121178f},
00117 {0.624689f,0.226675f},{0.613751f,0.258856f},{0.613751f,0.226675f},
00118 {0.624689f,0.258856f},{0.635626f,0.226675f},{0.635626f,0.258856f},
00119 {0.646564f,0.226675f},{0.646564f,0.258856f},{0.657502f,0.226675f},
00120 {0.657502f,0.258856f},{0.66844f,0.226675f},{0.66844f,0.258856f},
00121 {0.679377f,0.226675f},{0.679377f,0.258856f},{0.690315f,0.226675f},
00122 {0.690315f,0.258856f},{0.701253f,0.226675f},{0.701253f,0.258856f},
00123 {0.449685f,0.226675f},{0.438747f,0.257813f},{0.438747f,0.226675f},
00124 {0.449685f,0.258856f},{0.460623f,0.226675f},{0.460623f,0.258856f},
00125 {0.47156f,0.226675f},{0.47156f,0.258856f},{0.482498f,0.226675f},
00126 {0.482498f,0.258856f},{0.493436f,0.226675f},{0.493436f,0.258856f},
00127 {0.504374f,0.226675f},{0.504374f,0.258856f},{0.515311f,0.226675f},
00128 {0.515311f,0.258856f},{0.526249f,0.226675f},{0.526249f,0.258856f},
00129 {0.537187f,0.226675f},{0.537187f,0.258856f},{0.548125f,0.226675f},
00130 {0.548125f,0.258856f},{0.559062f,0.226675f},{0.559062f,0.258856f},
00131 {0.57f,0.226675f},{0.57f,0.258856f},{0.580938f,0.226675f},
00132 {0.580938f,0.258856f},{0.591875f,0.226675f},{0.591875f,0.258856f},
00133 {0.602813f,0.226675f},{0.602813f,0.258856f}
00134 };
00135 GLint GenFeederCharge2()
00136 {
00137 GLint lid=glGenLists(1);
00138 glNewList(lid, GL_COMPILE);
00139
00140 glBegin (GL_TRIANGLES);
00141 for(size_t i=0;i<sizeof(face_indicies)/sizeof(face_indicies[0]);i++)
00142 {
00143 for(size_t j=0;j<3;j++)
00144 {
00145 int vi=face_indicies[i][j];
00146 int ni=face_indicies[i][j+3];
00147 int ti=face_indicies[i][j+6];
00148
00149
00150
00151
00152
00153 glNormal3f (normals[ni][1],-normals[ni][0],normals[ni][2]);
00154 glTexCoord2f(textures[ti][0],textures[ti][1]);
00155 glVertex3f (100.f*vertices[vi][1],-100.f*vertices[vi][0],100.f*vertices[vi][2]);
00156 }
00157 }
00158 glEnd ();
00159
00160 glEndList();
00161 return lid;
00162 };
00163 }