Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/lib/graphics/importer/model.cc @ 6162

Last change on this file since 6162 was 6162, checked in by bensch, 18 years ago

orxonox/trunk: merged the spaceshipcontroll branche into the trunk
merged with command
svn merge -r6036:HEAD spaceshipcontrol/ ../trunk/
no conflicts

File size: 2.1 KB
RevLine 
[4744]1/*
[1853]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.
[1855]10
11   ### File Specific:
[6009]12   main-programmer: Patrick Boenzli
[1855]13   co-programmer: ...
[1853]14*/
15
[6009]16#define DEBUG_SPECIAL_MODULE DEBUG_MODULE_MODEL
[1853]17
[6021]18#include "model.h"
[1853]19
[6033]20#include "glincl.h"
21
[1856]22using namespace std;
[1853]23
[3245]24/**
[4838]25 * standard constructor
26 * @todo this constructor is not jet implemented - do it
[3245]27*/
[6021]28Model::Model()
[3365]29{
[6162]30  this->setClassID(CL_MODEL, "Model");
[6009]31  this->pModelInfo.numVertices = 0;
32  this->pModelInfo.numTriangles = 0;
[6073]33  this->pModelInfo.numNormals = 0;
[6009]34  this->pModelInfo.numTexCoor = 0;
[4320]35
[6009]36  this->pModelInfo.pVertices = NULL;
37  this->pModelInfo.pTriangles = NULL;
38  this->pModelInfo.pNormals = NULL;
39  this->pModelInfo.pTexCoor = NULL;
[3365]40}
[1853]41
42
[3245]43/**
[4838]44 * standard deconstructor
[3245]45*/
[6021]46Model::~Model()
[3543]47{
48  // delete what has to be deleted here
49}
[6033]50
51
52
53void Model::draw() const
54{
55  const GLfloat* pVertices = NULL;
56  const GLfloat* pNorm = NULL;
[6162]57
[6033]58  glBegin(GL_TRIANGLES);
59  for( int i = 0; i < this->pModelInfo.numTriangles; ++i)
60    {
61      //printf("int i = %i\n", i);
62      pNorm = &this->pModelInfo.pNormals[this->pModelInfo.pTriangles[i].indexToNormals[0]];
63      pVertices = &this->pModelInfo.pVertices[this->pModelInfo.pTriangles[i].indexToVertices[0]];
64      glNormal3f(pNorm[0], pNorm[1], pNorm[2]);
65      glVertex3f(pVertices[0], pVertices[1], pVertices[2]);
[6162]66
[6033]67      pNorm = &this->pModelInfo.pNormals[this->pModelInfo.pTriangles[i].indexToNormals[1]];
68      pVertices = &this->pModelInfo.pVertices[this->pModelInfo.pTriangles[i].indexToVertices[1]];
69      glNormal3f(pNorm[0], pNorm[1], pNorm[2]);
70      glVertex3f(pVertices[0], pVertices[1], pVertices[2]);
[6162]71
[6033]72      pNorm = &this->pModelInfo.pNormals[this->pModelInfo.pTriangles[i].indexToNormals[2]];
73      pVertices = &this->pModelInfo.pVertices[this->pModelInfo.pTriangles[i].indexToVertices[2]];
74      glNormal3f(pNorm[0], pNorm[1], pNorm[2]);
75      glVertex3f(pVertices[0], pVertices[1], pVertices[2]);
[6162]76
[6033]77    }
78  glEnd();
79}
Note: See TracBrowser for help on using the repository browser.