Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

Ignore:
Timestamp:
Jun 22, 2006, 1:51:50 PM (18 years ago)
Author:
ponder
Message:
  • Added special checks for macosx to acinclude.m4 and configure.ac. This sucks
  • Reapplied the endianness checks to the md2_model file. They got lost during the merge operation.
  • Tried to do the collision detection for the ground. But somehow it doesn't work. Perhaps an offset will do.
File:
1 edited

Legend:

Unmodified
Added
Removed
  • branches/terrain/src/lib/graphics/importer/md2/md2Model.cc

    r8490 r8715  
    1717#include "md2Model.h"
    1818#include "material.h"
    19 
     19#include "config.h"
     20#ifdef HAVE_SDL_SDL_H
     21#include <SDL/SDL.h>
     22#include <SDL/SDL_endian.h>
     23#else
     24#include <SDL.h>
     25#include <SDL_endian.h>
     26#endif
    2027#include "debug.h"
    2128#include "util/loading/resource_manager.h"
     
    6673  };
    6774
    68 
     75#ifdef SDL_LIL_ENDIAN
     76#define BULK_CONV( _ptr, _num ) do { \
     77        int  _cnt = _num;\
     78        int* _iptr = (int*)_ptr;\
     79        for( int _l = 0; _l<_cnt; ++_l )\
     80                _iptr[_l] = SDL_SwapLE32( _iptr[_l] );\
     81} while( 0 )
     82#define BULK_CONV16( _ptr, _num ) do { \
     83        short  _cnt = _num;\
     84        short* _iptr = (short*)_ptr;\
     85        for( int _l = 0; _l<_cnt; ++_l )\
     86                _iptr[_l] = SDL_SwapLE16( _iptr[_l] );\
     87} while( 0 )
     88#else
     89#define BULK_CONV( _ptr, _num )
     90#define BULK_CONV16( _ptr, _num )
     91#endif
    6992
    7093/********************************************************************************
     
    442465  this->header = new MD2Header;
    443466  fread(this->header, 1, sizeof(MD2Header), pFile);
     467        BULK_CONV( this->header, sizeof(MD2Header)/4 );
    444468  /* check for the header version: make sure its a md2 file :) */
    445   if( unlikely(this->header->version != MD2_VERSION) && unlikely(this->header->ident != MD2_IDENT))
     469  if( unlikely( this->header->version != MD2_VERSION) && unlikely( this->header->ident != MD2_IDENT))
    446470    {
    447471      PRINTF(1)("Couldn't load file %s: invalid file format: stop loading\n", fileName.c_str());
     
    449473    }
    450474
    451   this->fileName =fileName;
     475  this->fileName = fileName;
    452476  /* got the data: map it to locals */
    453477  this->numFrames = this->header->numFrames;
     
    468492  fseek(pFile, this->header->offsetFrames, SEEK_SET);
    469493  fread(buffer, this->header->frameSize, this->numFrames, pFile);
     494        //BULK_CONV( buffer, this->header->frameSize*this->numFrames*sizeof(char)/4 );
    470495  /* read opengl commands */
    471496  fseek(pFile, this->header->offsetGlCommands, SEEK_SET);
     497
    472498  fread(this->pGLCommands, sizeof(int), this->numGLCommands, pFile);
     499        BULK_CONV( this->pGLCommands, this->numGLCommands );
    473500  /* triangle list */
    474501  fseek(pFile, this->header->offsetTriangles, SEEK_SET);
    475   fread(this->pTriangles, sizeof(sTriangle), this->numTriangles, pFile);
     502  fread(this->pTriangles, sizeof(sTriangle), this->numTriangles, pFile);       
     503        BULK_CONV16( this->pTriangles, this->numTriangles*sizeof(sTriangle)/2 );
     504
    476505  /*  read in texture coordinates */
    477506  fseek(pFile, this->header->offsetTexCoords, SEEK_SET);
    478507  fread(this->pTexCoor, sizeof(sTexCoor), this->numTexCoor, pFile);
    479 
     508        BULK_CONV16( this->pTexCoor, this->numTexCoor*sizeof(sTexCoor)/2 );
    480509
    481510  for(int i = 0; i < this->numFrames; ++i)
    482511    {
    483512      frame = (sFrame*)(buffer + this->header->frameSize * i);
     513                        //Convert the translate and scale Vec3D if needed.
     514                        BULK_CONV( frame, 6 );
     515                        BULK_CONV( frame->pVertices, 3 );
    484516      pVertex = this->pVertices + this->numVertices  * i;
    485517      pNormals = this->pLightNormals + this->numVertices * i;
Note: See TracChangeset for help on using the changeset viewer.