Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/network/src/world_entities/spawning_point.cc @ 6091

Last change on this file since 6091 was 6088, checked in by patrick, 19 years ago

network: more constructor work, loadparam completed

File size: 3.0 KB
Line 
1
2/*
3   orxonox - the future of 3D-vertical-scrollers
4
5   Copyright (C) 2004 orx
6
7   This program is free software; you can redistribute it and/or modify
8   it under the terms of the GNU General Public License as published by
9   the Free Software Foundation; either version 2, or (at your option)
10   any later version.
11
12### File Specific:
13   main-programmer: Patrick Boenzli
14   co-programmer:
15*/
16
17#include "spawning_point.h"
18#include "load_param.h"
19
20
21/**
22 *  standard constructor
23 */
24SpawningPoint::SpawningPoint (const Vector& absCoordinate, const World* world)
25    : WorldEntity(absCoodrinate)
26{
27  this->world = world;
28  this->frequency = 0.5f;
29  this->seed = 0.0f;
30
31  this->init();
32}
33
34
35/**
36 *  constructor
37 */
38SpawningPoint::SpawningPoint (const Vector& position, float frequency,
39                              float seed, int classID, const World* world)
40    : WorldEntity(position)
41{
42  this->frequency = frequency;
43  this->seed = seed;
44  this->classID = classID;
45  this->world = world;
46
47  this->init();
48}
49
50
51void SpawningPoint::init()
52{
53  this->countDown = 0.0f;
54}
55
56
57/**
58 *  deconstructor
59 */
60SpawningPoint::~SpawningPoint ()
61{}
62
63
64/**
65 * loads the WorldEntity Specific Parameters.
66 * @param root: the XML-Element to load the Data From
67 */
68void SpawningPoint::loadParams(const TiXmlElement* root)
69{
70  /* let the world entity its stuff first */
71  static_cast<WorldEntity*>(this)->loadParams(root);
72
73  /* now load the frequency */
74  LoadParam(root, "frequency", this, SpawningPoint, setSpawningFrequency)
75  .describe("sets the frequency of the spawning point")
76  .defaultValues(1, 1.0f);
77
78
79  /* now load the seed */
80  LoadParam(root, "randomseed", this, SpawningPoint, setPositionSeed)
81      .describe("sets the random position seed (variance in the spawning location around the position)")
82      .defaultValues(1, 0.0f);
83
84  /* now load the seed */
85  LoadParam(root, "classid", this, SpawningPoint, setSpawningEntity)
86      .describe("sets the class id of the entity to spawn")
87      .defaultValues(1, CL_WORLD_ENTITY);
88}
89
90
91/**
92 *  spawn the entity
93 */
94void SpawningPoint::spawn()
95{
96  PRINTF(5)("Spangingpoint creates a new Entity (id: %i, frequency: %f, seed: %f)\n", this->classID,
97            this->frequency, this->seed);
98  BaseObject* spawningEntity = Factory::fabricate(this->classID);
99  if( LIKELY(this->world != NULL))
100    this->world->spawn(dynamic_cast<WorldEntity*>(spawningEntity));
101}
102
103
104/**
105 *  this method is called every frame
106 * @param time: the time in seconds that has passed since the last tick
107 *
108 * Handle all stuff that should update with time inside this method (movement, animation, etc.)
109 */
110void SpawningPoint::tick(float dt)
111{
112  this->countDown += dt;
113  if( this->countDown > this->frequency)
114  {
115    this->spawn();
116    this->countDown = 0.0f;
117  }
118}
119
120
121/**
122 *  the entity is drawn onto the screen with this function
123 *
124 * This is a central function of an entity: call it to let the entity painted to the screen.
125 * Just override this function with whatever you want to be drawn.
126 */
127void SpawningPoint::draw()
128{}
Note: See TracBrowser for help on using the repository browser.