Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/mount_points/src/lib/graphics/importer/static_model.cc @ 10134

Last change on this file since 10134 was 10134, checked in by patrick, 17 years ago

mount point work

File size: 6.6 KB
Line 
1/*
2   orxonox - the future of 3D-vertical-scrollers
3
4   Copyright (C) 2004 orx
5
6   This program is free software; you can redistribute it and/or modify
7   it under the terms of the GNU General Public License as published by
8   the Free Software Foundation; either version 2, or (at your option)
9   any later version.
10
11   ### File Specific:
12   main-programmer: Benjamin Grauer
13   co-programmer: ...
14
15   2005-07-06: (Patrick) added new function buildTriangleList()
16*/
17
18#define DEBUG_SPECIAL_MODULE DEBUG_MODULE_IMPORTER
19
20#include "static_model.h"
21
22#include "debug.h"
23#include <stdarg.h>
24
25
26
27
28/////////////
29/// MODEL ///
30/////////////
31ObjectListDefinition(StaticModel);
32
33/**
34 * @brief Creates a 3D-Model.
35 *
36 * assigns it a Name and a Type
37 */
38StaticModel::StaticModel(const std::string& modelName)
39    : data(new StaticModelData(modelName))
40{
41  this->registerObject(this, StaticModel::_objectList);
42  PRINTF(4)("new 3D-Model is being created\n");
43  this->setName(modelName);
44}
45
46StaticModel::StaticModel(const StaticModel& staticModel)
47  : data(staticModel.data)
48{
49  this->registerObject(this, StaticModel::_objectList);
50  this->setName(staticModel.getName());
51  this->updateBase();
52}
53
54
55/**
56 * @brief deletes an Model.
57 *
58 * Looks if any from model allocated space is still in use, and if so deleted it.
59 */
60StaticModel::~StaticModel()
61{
62  PRINTF(4)("Deleting Model ");
63
64  // mark this stuff as beeing deleted
65  this->pModelInfo.pVertices = NULL;
66  this->pModelInfo.pNormals = NULL;
67  this->pModelInfo.pTexCoor = NULL;
68  this->pModelInfo.pTriangles = NULL;
69}
70
71StaticModel& StaticModel::operator=(const StaticModel& model)
72{
73  this->data = model.data;
74  this->updateBase();
75  return *this;
76};
77
78
79/**
80 * @brief Finalizes an Object. This can be done outside of the Class.
81 */
82void StaticModel::finalize()
83{
84  data->finalize();
85  this->updateBase();
86}
87
88void StaticModel::acquireData(const StaticModelData::Pointer& data)
89{
90  this->data = data;
91  this->updateBase();
92}
93
94
95
96/**
97 * extract the mount points from this file: looking at each group and checking if the group realy is a mountpoint marker
98 * if so get place and orientation
99 */
100void StaticModel::extractMountPoints()
101{
102
103  // go through all groups and check if they are mounts
104  const ModelGroup* groupPtr = this->data->getModelGroup();
105  for( ; groupPtr != NULL; groupPtr = groupPtr->next)
106  {
107    //PRINTF(0)("Found a MountPoint: %s\n", groupName.c_str());
108
109    // get the name of this group and check if it's a mout point identifier
110    std::string groupName = groupPtr->name;
111    if( groupName.find("MP.", 0) != std::string::npos)
112    {
113      PRINTF(0)("Found a MountPoint: %s\n", groupName.c_str());
114
115      // now check if it is a mount point identifier
116      if( groupPtr->faceCount != 5) {
117        PRINTF(1)("the face count of %s is wrong, perhaps you missnamed this object or used the wrong mount point object\n", groupName.c_str());
118      }
119
120      // now extract the direction from the length:
121      ModelFace* mf = groupPtr->firstFace;
122      for( ; mf != NULL; mf = mf->next)
123      {
124        // now go through all modelfaceelements
125        ModelFaceElement* mfe = mf->firstElem;
126        for( ; mfe != NULL; mfe = mfe->next)
127        {
128          int vert = mfe->vertexNumber;
129          this->data->getVertices()[vert*3];
130
131        }
132      }
133
134    }
135
136  }
137
138
139}
140
141
142
143/**
144 * @brief adds a new Face
145 * @param faceElemCount the number of Vertices to add to the Face.
146 * @param type The information Passed with each Vertex
147*/
148bool StaticModel::addFace(int faceElemCount, VERTEX_FORMAT type, ...)
149{
150  va_list itemlist;
151  va_start (itemlist, type);
152  bool retVal = this->data->addFace(faceElemCount, type, itemlist);
153  va_end(itemlist);
154  return retVal;
155}
156
157void StaticModel::updateBase()
158{
159  // write out the modelInfo data used for the collision detection!
160  this->pModelInfo.pVertices = &this->data->getVertices()[0];
161  this->pModelInfo.numVertices = this->data->getVertices().size();
162  this->pModelInfo.pNormals = &this->data->getNormals()[0];
163  this->pModelInfo.numNormals = this->data->getNormals().size();
164  this->pModelInfo.pTexCoor = &this->data->getTexCoords()[0];
165  this->pModelInfo.numTexCoor = this->data->getTexCoords().size();
166
167  this->pModelInfo.pTriangles = this->data->getTrianglesExt();
168  this->pModelInfo.numTriangles = this->data->getTriangles().size();
169}
170
171
172/**
173 *  Includes a default model
174 *
175 * This will inject a Cube, because this is the most basic model.
176 */
177void StaticModel::cubeModel()
178{
179  this->addVertex (-0.5, -0.5, 0.5);
180  this->addVertex (0.5, -0.5, 0.5);
181  this->addVertex (-0.5, 0.5, 0.5);
182  this->addVertex (0.5, 0.5, 0.5);
183  this->addVertex (-0.5, 0.5, -0.5);
184  this->addVertex (0.5, 0.5, -0.5);
185  this->addVertex (-0.5, -0.5, -0.5);
186  this->addVertex (0.5, -0.5, -0.5);
187
188  this->addVertexTexture (0.0, 0.0);
189  this->addVertexTexture (1.0, 0.0);
190  this->addVertexTexture (0.0, 1.0);
191  this->addVertexTexture (1.0, 1.0);
192  this->addVertexTexture (0.0, 2.0);
193  this->addVertexTexture (1.0, 2.0);
194  this->addVertexTexture (0.0, 3.0);
195  this->addVertexTexture (1.0, 3.0);
196  this->addVertexTexture (0.0, 4.0);
197  this->addVertexTexture (1.0, 4.0);
198  this->addVertexTexture (2.0, 0.0);
199  this->addVertexTexture (2.0, 1.0);
200  this->addVertexTexture (-1.0, 0.0);
201  this->addVertexTexture (-1.0, 1.0);
202
203  this->addVertexNormal (0.0, 0.0, 1.0);
204  this->addVertexNormal (0.0, 0.0, 1.0);
205  this->addVertexNormal (0.0, 0.0, 1.0);
206  this->addVertexNormal (0.0, 0.0, 1.0);
207  this->addVertexNormal (0.0, 1.0, 0.0);
208  this->addVertexNormal (0.0, 1.0, 0.0);
209  this->addVertexNormal (0.0, 1.0, 0.0);
210  this->addVertexNormal (0.0, 1.0, 0.0);
211  this->addVertexNormal (0.0, 0.0, -1.0);
212  this->addVertexNormal (0.0, 0.0, -1.0);
213  this->addVertexNormal (0.0, 0.0, -1.0);
214  this->addVertexNormal (0.0, 0.0, -1.0);
215  this->addVertexNormal (0.0, -1.0, 0.0);
216  this->addVertexNormal (0.0, -1.0, 0.0);
217  this->addVertexNormal (0.0, -1.0, 0.0);
218  this->addVertexNormal (0.0, -1.0, 0.0);
219  this->addVertexNormal (1.0, 0.0, 0.0);
220  this->addVertexNormal (1.0, 0.0, 0.0);
221  this->addVertexNormal (1.0, 0.0, 0.0);
222  this->addVertexNormal (1.0, 0.0, 0.0);
223  this->addVertexNormal (-1.0, 0.0, 0.0);
224  this->addVertexNormal (-1.0, 0.0, 0.0);
225  this->addVertexNormal (-1.0, 0.0, 0.0);
226  this->addVertexNormal (-1.0, 0.0, 0.0);
227
228  this->addFace (4, VERTEX_TEXCOORD_NORMAL, 0,0,0, 1,1,1, 3,3,2, 2,2,3);
229  this->addFace (4, VERTEX_TEXCOORD_NORMAL, 2,2,4, 3,3,5, 5,5,6, 4,4,7);
230  this->addFace (4, VERTEX_TEXCOORD_NORMAL, 4,4,8, 5,5,9, 7,7,10, 6,6,11);
231  this->addFace (4, VERTEX_TEXCOORD_NORMAL, 6,6,12, 7,7,13, 1,9,14, 0,8,15);
232  this->addFace (4, VERTEX_TEXCOORD_NORMAL, 1,1,16, 7,10,17, 5,11,18, 3,3,19);
233  this->addFace (4, VERTEX_TEXCOORD_NORMAL, 6,12,20, 0,0,21, 2,2,22, 4,13,23);
234}
Note: See TracBrowser for help on using the repository browser.