Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

Changeset 3542 in orxonox.OLD for orxonox/branches/levelloader


Ignore:
Timestamp:
Mar 14, 2005, 9:58:58 AM (20 years ago)
Author:
chris
Message:

orxonox/branches/levelloader: First incarnation of a debugworld loaded from a XML-File in place, compilability in place, all necessary basic loading constuctors in place. Unfortunately the code still generates interferences with the old hardcoded debugworld resulting in SegFault crash.

Location:
orxonox/branches/levelloader/src
Files:
12 edited

Legend:

Unmodified
Added
Removed
  • orxonox/branches/levelloader/src/defs/debug.h

    r3530 r3542  
    2727
    2828#include <stdio.h>
     29
     30#ifndef DEBUG
     31#define DEBUG 4
     32#endif
    2933
    3034#define NO              0
  • orxonox/branches/levelloader/src/factory.cc

    r3530 r3542  
    6363{
    6464        assert( classname != NULL);
    65         PRINTF(3)("Initializing %sFactory\n", classname);
    6665        GameLoader* gl = GameLoader::getInstance();
    6766        gl->registerFactory( this);
  • orxonox/branches/levelloader/src/game_loader.cc

    r3530 r3542  
    161161  if( name == NULL)
    162162  {
    163                 PRINTF(1)("No filename specified for loading");
     163                PRINTF0("No filename specified for loading");
    164164                return NULL;
    165165  }
     
    170170        {
    171171                // report an error
    172                 PRINTF(1)("Error loading XML File: %s @ %d:%d\n", XMLDoc->ErrorDesc(), XMLDoc->ErrorRow(), XMLDoc->ErrorCol());
     172                PRINTF0("Error loading XML File: %s @ %d:%d\n", XMLDoc->ErrorDesc(), XMLDoc->ErrorRow(), XMLDoc->ErrorCol());
    173173                delete XMLDoc;
    174174                return NULL;
     
    176176       
    177177        // check basic validity
    178         TiXmlElement* element = XMLDoc->RootElement();
    179         assert( element != NULL);
    180        
    181         element = element->FirstChildElement( "Campaign");
    182        
    183         if( element == NULL )
     178        TiXmlElement* root = XMLDoc->RootElement();
     179        assert( root != NULL);
     180       
     181        if( strcmp( root->Value(), "Campaign"))
    184182        {
    185183                // report an error
    186                 PRINTF(1)("Specified XML File is not an orxonox campaign file (Campaign element missing)\n");
     184                PRINTF0("Specified XML File is not an orxonox campaign file (Campaign element missing)\n");
    187185                delete XMLDoc;
    188186                return NULL;
     
    190188       
    191189        // construct campaign
    192         Campaign* c = new Campaign( element);
     190        Campaign* c = new Campaign( root);
    193191       
    194192        // free the XML data
     
    272270        assert( factory != NULL);
    273271       
    274         printf("Registered factory for '%s'\n", factory->getClassname());
     272        PRINTF0("Registered factory for '%s'\n", factory->getClassname());
    275273       
    276274        if( first == NULL) first = factory;
     
    286284        if( first == NULL)
    287285        {
    288                 PRINTF(1)("GameLoader does not know any factories, fabricate() failed\n");
     286                PRINTF0("GameLoader does not know any factories, fabricate() failed\n");
    289287                return NULL;
    290288        }
  • orxonox/branches/levelloader/src/lib/graphics/importer/objModel.cc

    r3499 r3542  
    2424   \param fileName file to parse and load (must be a .obj file)
    2525*/
    26 OBJModel::OBJModel(char* fileName)
     26OBJModel::OBJModel(const char* fileName)
    2727{
    2828  this->initializeOBJ();
     
    4040   \param scaling The factor that the model will be scaled with.
    4141*/
    42 OBJModel::OBJModel(char* fileName, float scaling)
     42OBJModel::OBJModel(const char* fileName, float scaling)
    4343{
    4444  this->initializeOBJ();
     
    8484   \param fileName The file to import
    8585*/
    86 bool OBJModel::importFile (char* fileName)
     86bool OBJModel::importFile (const char* fileName)
    8787{
    8888  PRINTF(3)("preparing to read in file: %s\n", fileName);
     
    9696  char pathSplitter='/';
    9797#endif /* __WIN32__ */
    98   char* tmpName = fileName;
     98  const char* tmpName = fileName;
    9999  if (tmpName[0] == pathSplitter)
    100100    tmpName++;
    101   char* name = tmpName;
     101  const char* name = tmpName;
    102102  while (( tmpName = strchr (tmpName+1, pathSplitter)))
    103103    {
     
    212212
    213213*/
    214 bool OBJModel::readMtlLib (char* mtlFile)
     214bool OBJModel::readMtlLib (const char* mtlFile)
    215215{
    216216  this->mtlFileName = new char [strlen(mtlFile)+1];
  • orxonox/branches/levelloader/src/lib/graphics/importer/objModel.h

    r3499 r3542  
    1313{
    1414 public:
    15   OBJModel(char* fileName);
    16   OBJModel(char* fileName, float scaling);
     15  OBJModel(const char* fileName);
     16  OBJModel(const char* fileName, float scaling);
    1717  virtual ~OBJModel();
    1818  void initializeOBJ(void);
     
    2525
    2626  ///// readin /////
    27   bool importFile (char* fileName);
     27  bool importFile (const char* fileName);
    2828  bool readFromObjFile (void);
    29   bool readMtlLib (char* matFile);
     29  bool readMtlLib (const char* matFile);
    3030
    3131};
  • orxonox/branches/levelloader/src/orxonox.cc

    r3499 r3542  
    251251 
    252252  this->gameLoader = GameLoader::getInstance();
    253   this->gameLoader->loadDebugCampaign(DEBUG_CAMPAIGN_0);
     253  this->gameLoader->loadCampaign("../data/worlds/DefaultCampaign.oxc");
     254  //this->gameLoader->loadDebugCampaign(DEBUG_CAMPAIGN_0);
    254255  this->gameLoader->init();
    255256  this->gameLoader->start();
  • orxonox/branches/levelloader/src/story_entities/campaign.cc

    r3530 r3542  
    5656        }
    5757        else this->setStoryID( id);
    58        
     58 
    5959  // find WorldList
    6060  element = root->FirstChildElement( "WorldList");
    6161 
    6262  // load Worlds/Subcampaigns/Whatever
     63  StoryEntity* lastCreated = NULL;
    6364        while( element != NULL)
    6465        {
    6566                StoryEntity* created = (StoryEntity*) loader->fabricate( element);
    66                 if( created != NULL) addEntity( created);
     67                if( lastCreated != NULL) created->setNextStoryID( lastCreated->getStoryID());
     68                if( created != NULL)
     69                {
     70                        this->addEntity( created);     
     71                        lastCreated = created;
     72                }
    6773                element = element->NextSiblingElement();
    6874        }
     75        if( lastCreated != NULL)        lastCreated->setStoryID( WORLD_ID_GAMEEND);
    6976}
    7077
  • orxonox/branches/levelloader/src/story_entities/world.cc

    r3530 r3542  
    4242        int id;
    4343
     44        PRINTF0("Creating a World\n");
     45       
    4446        // identifier
    4547        string = grabParameter( root, "identifier");
    4648        if( string == NULL || sscanf(string, "%d", &id) != 1)
    4749        {
    48                 PRINTF(1)("World is missing a proper 'identifier'\n");
     50                PRINTF0("World is missing a proper 'identifier'\n");
    4951                this->setStoryID( -1);
    5052        }
     
    5557        if( string == NULL)
    5658        {
    57                 PRINTF(1)("World is missing a proper 'path'\n");
     59                PRINTF0("World is missing a proper 'path'\n");
    5860                this->setPath( NULL);
    5961        }
     
    6567        }
    6668       
    67        
     69        localPlayer = NULL;
     70               
    6871}
    6972
     
    138141ErrorMessage World::load()
    139142{
     143       
     144        PRINTF0("Loading world: '%s'\n", getPath());
     145       
    140146        GameLoader* loader = GameLoader::getInstance();
    141147       
    142148  if( getPath() == NULL)
    143149  {
    144                 PRINTF(1)("World has no path specified for loading");
     150                PRINTF0("World has no path specified for loading");
    145151                return (ErrorMessage){213,"Path not specified","World::load()"};
    146152  }
     
    151157        {
    152158                // report an error
    153                 PRINTF(1)("Error loading XML File: %s @ %d:%d\n", XMLDoc->ErrorDesc(), XMLDoc->ErrorRow(), XMLDoc->ErrorCol());
     159                PRINTF0("Error loading XML File: %s @ %d:%d\n", XMLDoc->ErrorDesc(), XMLDoc->ErrorRow(), XMLDoc->ErrorCol());
    154160                delete XMLDoc;
    155161                return (ErrorMessage){213,"XML File parsing error","World::load()"};
     
    165171        {
    166172                // report an error
    167                 PRINTF(1)("Specified XML File is not an orxonox world data file (WorldDataFile element missing)\n");
     173                PRINTF0("Specified XML File is not an orxonox world data file (WorldDataFile element missing)\n");
    168174                delete XMLDoc;
    169175                return (ErrorMessage){213,"Path not a WorldDataFile","World::load()"};
     
    176182        if( string == NULL)
    177183        {
    178                 PRINTF(1)("World is missing a proper 'name'\n");
    179                 this->setStoryID( -1);
     184                PRINTF0("World is missing a proper 'name'\n");
     185                string = "Unknown";
     186                temp = new char[strlen(string + 2)];
     187                strcpy( temp, string);
     188                this->worldName = temp;
    180189        }
    181190        else
    182191        {
    183192                temp = new char[strlen(string + 2)];
     193                strcpy( temp, string);
    184194                this->worldName = temp;
    185195        }
     
    191201  if( element == NULL)
    192202  {
    193                 PRINTF(1)("World is missing 'WorldEntities'\n");
     203                PRINTF0("World is missing 'WorldEntities'\n");
    194204  }
    195205  else
     
    201211                        WorldEntity* created = (WorldEntity*) loader->fabricate( element);
    202212                        if( created != NULL) spawn( created);
     213                        assert( element->Value() != NULL);
     214                                // if we load a 'Player' we use it as localPlayer
     215                        if( !strcmp( element->Value(), "Player")) localPlayer = (Player*) created;
    203216                        element = element->NextSiblingElement();
    204217                }
     
    209222  if( element == NULL)
    210223  {
    211                 PRINTF(1)("World is missing a 'Track'\n");
     224                PRINTF0("World is missing a 'Track'\n");
    212225  }
    213226  else
     
    216229        trackManager = TrackManager::getInstance();
    217230        trackManager->loadTrack( element);
    218         }
    219  
     231        trackManager->finalize();
     232        }
     233
    220234       
    221235        // free the XML data
    222236        delete XMLDoc;
    223237       
    224   //  BezierCurve* tmpCurve = new BezierCurve();
    225   if(this->debugWorldNr != -1)
    226     {
    227       // initializing Font
    228       testFont = new FontSet();
    229       testFont->buildFont("../data/pictures/font.tga");
    230 
     238        // finalize world
     239          // initialize Font
     240          testFont = new FontSet();
     241          testFont->buildFont("../data/pictures/font.tga");
     242       
     243                // create null parent
     244    this->nullParent = NullParent::getInstance ();
     245    this->nullParent->setName ("NullParent");
     246   
     247    // finalize myPlayer
     248                if( localPlayer == NULL)
     249                {
     250                        PRINTF0("No Player specified in World '%s'\n", this->worldName);
     251                        return (ErrorMessage){213,"No Player defined","World::load()"};
     252                }
     253               
     254        // bind input
     255    Orxonox *orx = Orxonox::getInstance ();
     256    orx->getLocalInput()->bind (localPlayer);
     257   
     258        // bind camera
     259    this->localCamera = new Camera(this);
     260    this->localCamera->setName ("camera");
     261    this->localCamera->bind (localPlayer);
     262    this->localPlayer->addChild (this->localCamera);
     263
     264       
     265        // stuff beyond this point remains to be loaded properly
     266       
    231267      /*monitor progress*/
    232       this->glmis->step();
    233 
    234       /*
    235         tmpCurve->addNode(Vector(10,  -1,  -1));
    236         tmpCurve->addNode(Vector(10,  -2,   2));
    237         tmpCurve->addNode(Vector(10,   3,   3));
    238         tmpCurve->addNode(Vector(10,   4,  -4), 0);
    239         tmpCurve->addNode(Vector(10,  -1,  -1));
    240         tmpCurve->addNode(Vector(10,  -2,   2));
    241         tmpCurve->addNode(Vector(10,   3,   3));
    242         tmpCurve->addNode(Vector(10,   4,  -4), 0);
    243         tmpCurve->debug();
    244       */
    245       switch(this->debugWorldNr)
    246         {
    247           /*
    248             this loads the hard-coded debug world. this only for simplicity and will be
    249             removed by a reald world-loader, which interprets a world-file.
    250             if you want to add an own debug world, just add a case DEBUG_WORLD_[nr] and
    251             make whatever you want...
    252            */
    253         case DEBUG_WORLD_0:
    254           {
    255             this->nullParent = NullParent::getInstance ();
    256             this->nullParent->setName ("NullParent");
    257 
    258             // !\todo old track-system has to be removed
    259 
    260             //create helper for player
    261             HelperParent* hp = new HelperParent ();
    262             /* the player has to be added to this helper */
    263 
    264             // create a player
    265             WorldEntity* myPlayer = new Player ();
    266             myPlayer->setName ("player");
    267             this->spawn (myPlayer);
    268             this->localPlayer = myPlayer;
    269             /*monitor progress*/
    270             this->glmis->step();           
    271 
    272             // bind input
    273             Orxonox *orx = Orxonox::getInstance ();
    274             orx->getLocalInput()->bind (myPlayer);
    275            
    276             // bind camera
    277             this->localCamera = new Camera(this);
    278             this->localCamera->setName ("camera");
    279             this->localCamera->bind (myPlayer);
    280             this->localPlayer->addChild (this->localCamera);
     268  //  this->glmis->step();
    281269
    282270            // Create SkySphere
     
    284272
    285273            /*monitor progress*/
    286             this->glmis->step();
    287 
    288             Vector* es = new Vector (50, 2, 0);
    289             Quaternion* qs = new Quaternion ();
    290             WorldEntity* env = new Environment();
    291             env->setName ("env");
    292             this->spawn(env, es, qs);
    293            
    294             /*monitor progress*/
    295             this->glmis->step();
    296 
    297             trackManager->setBindSlave(env);
    298 
    299             break;
    300           }
    301         case DEBUG_WORLD_1:
    302           {
    303             /*
    304             this->testCurve = new UPointCurve();
    305             this->testCurve->addNode(Vector( 0, 0, 0));
    306             this->testCurve->addNode(Vector(10, 0, 5));
    307             this->testCurve->addNode(Vector(20, -5,-5));
    308             this->testCurve->addNode(Vector(30, 5, 10));
    309             this->testCurve->addNode(Vector(40, 0,-10));
    310             this->testCurve->addNode(Vector(50, 0,-10));
    311             */
    312 
    313             this->nullParent = NullParent::getInstance ();
    314             this->nullParent->setName ("NullParent");
    315 
    316 
    317 
    318             // create a player
    319             WorldEntity* myPlayer = new Player();
    320             myPlayer->setName ("player");
    321             this->spawn(myPlayer);
    322             this->localPlayer = myPlayer;           
    323            
    324             // bind input
    325             Orxonox *orx = Orxonox::getInstance();
    326             orx->getLocalInput()->bind (myPlayer);
    327            
    328             // bind camera
    329             this->localCamera = new Camera (this);
    330             this->localCamera->setName ("camera");
    331             this->localCamera->bind (myPlayer);
    332             this->localPlayer->addChild (this->localCamera);
    333 
    334             // Create SkySphere
    335             skySphere = new Skysphere("../data/pictures/sky-replace.jpg");
    336 
    337             break;
    338 
    339 
    340           }
    341         default:
    342           printf("World::load() - no world with ID %i found", this->debugWorldNr );
    343         }
    344     }
    345   else if(this->worldName != NULL)
    346     {
    347 
    348     }
     274          //  this->glmis->step();
     275         
     276          //  trackManager->setBindSlave(env);
    349277
    350278  // initialize debug coord system
  • orxonox/branches/levelloader/src/world_entities/environment.cc

    r3499 r3542  
    2626
    2727
     28CREATE_FACTORY(Environment);
    2829
    2930Environment::Environment () : WorldEntity()
     
    3233}
    3334
    34 
     35Environment::Environment ( TiXmlElement* root)
     36{
     37        char* temp;
     38        const char* string = grabParameter( root, "name");
     39        if( string == NULL)
     40        {
     41                PRINTF(1)("Environment is missing a proper 'name'\n");
     42                string = "Unknown";
     43                temp = new char[strlen(string + 2)];
     44                strcpy( temp, string);
     45                this->setName( temp);
     46        }
     47        else
     48        {
     49                temp = new char[strlen(string + 2)];
     50                strcpy( temp, string);
     51                this->setName( temp);
     52        }
     53       
     54        this->model = NULL;
     55        string = grabParameter( root, "model");
     56        if( string != NULL)
     57                this->model = new OBJModel( string);
     58        else
     59        {
     60                PRINTF(1)("Environment is missing a proper 'model'\n");
     61                this->model = new OBJModel( "../data/models/reaplow.obj");
     62        }
     63        if( this->model == NULL)
     64        {
     65                PRINTF(1)("Environment model '%s' could not be loaded\n", string);
     66        }
     67       
     68        double buff[3];
     69       
     70        string = grabParameter( root, "position");
     71        if( string != NULL && sscanf( string, "%f,%f,%f", &(buff[0]), &(buff[1]), &(buff[2])) == 3)
     72        {
     73                Vector* es = new Vector( buff[0], buff[1], buff[2]);
     74                this->setAbsCoor(es);
     75                delete es;
     76        }
     77        else
     78        {
     79                PRINTF(1)("Environment is missing a proper 'position'\n");
     80                Vector* es = new Vector();
     81                this->setAbsCoor(es);
     82                delete es;
     83        }
     84       
     85        string = grabParameter( root, "orientation");
     86        if( string != NULL && sscanf( string, "%f,%f,%f", &(buff[0]), &(buff[1]), &(buff[2])) == 3)
     87        {
     88                Quaternion* qs = new Quaternion( buff[0], buff[1], buff[2]);
     89                this->setAbsDir(qs);
     90                delete qs;
     91        }
     92        else
     93        {
     94                PRINTF(1)("Environment is missing a proper 'orientation'\n");
     95        Quaternion* qs = new Quaternion ();
     96                this->setAbsDir(qs);
     97                delete qs;
     98        }
     99}
    35100
    36101Environment::~Environment ()
  • orxonox/branches/levelloader/src/world_entities/environment.h

    r3499 r3542  
    1818 public:
    1919  Environment ();
     20  Environment (TiXmlElement* root);
    2021  ~Environment ();
    2122
  • orxonox/branches/levelloader/src/world_entities/player.cc

    r3499 r3542  
    2222
    2323using namespace std;
     24
     25CREATE_FACTORY(Player);
    2426
    2527/**
     
    5961
    6062/**
     63   \brief creates a new Player from Xml Data
     64   \param root the xml element containing player data
     65   
     66   \todo add more parameters to load
     67*/
     68Player::Player(TiXmlElement* root)
     69{
     70        char* temp;
     71        const char* string;
     72        string = grabParameter( root, "name");
     73        if( string == NULL)
     74        {
     75                PRINTF(1)("Player is missing a proper 'name'\n");
     76                string = "Unknown";
     77                temp = new char[strlen(string + 2)];
     78                strcpy( temp, string);
     79                this->setName( temp);
     80        }
     81        else
     82        {
     83                temp = new char[strlen(string + 2)];
     84                strcpy( temp, string);
     85                this->setName( temp);
     86        }
     87       
     88        this->model = NULL;
     89        string = grabParameter( root, "model");
     90        if( string != NULL)
     91                this->model = new OBJModel( string);
     92        else
     93        {
     94                PRINTF(1)("Player is missing a proper 'model'\n");
     95                this->model = new OBJModel( "../data/models/reaplow.obj");
     96        }
     97        if( this->model == NULL)
     98        {
     99                PRINTF(1)("Player model '%s' could not be loaded\n", string);
     100        }
     101}
     102
     103/**
    61104   \brief destructs the player
    62105*/
  • orxonox/branches/levelloader/src/world_entities/player.h

    r3499 r3542  
    1818 public:
    1919  Player(bool isFree = false);
     20  Player(TiXmlElement* root);
    2021  ~Player();
    2122 
Note: See TracChangeset for help on using the changeset viewer.