Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/world_entities/camera.cc @ 10402

Last change on this file since 10402 was 10396, checked in by snellen, 18 years ago

camer scripting WORKS

File size: 11.8 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: Christian Meyer
13   co-programmer: Benjamin Grauer
14*/
15#define DEBUG_SPECIAL_MODULE DEBUG_MODULE_WORLD_ENTITY
16
17#include "camera.h"
18#include "key_mapper.h"
19#include "glincl.h"
20#include "util/loading/load_param.h"
21#include "world_entity.h"
22#include "vector.h"
23#include "targets.h"
24#include "track/track.h"
25#include "script_class.h"
26
27
28ObjectListDefinition(Camera);
29
30CREATE_SCRIPTABLE_CLASS(Camera,
31                        addMethod("setAbsCoor", Executor3<PNode, lua_State*,float,float,float>(&PNode::setAbsCoor))
32                        ->addMethod("getAbsCoorX", Executor0ret<PNode, lua_State*, float>(&PNode::getAbsCoorX))
33                        ->addMethod("getAbsCoorY", Executor0ret<PNode, lua_State*, float>(&PNode::getAbsCoorY))
34                        ->addMethod("getAbsCoorZ", Executor0ret<PNode, lua_State*, float>(&PNode::getAbsCoorZ))
35                       );
36
37/**
38 *  creates a Camera
39*/
40Camera::Camera()
41{
42  this->registerObject(this, Camera::_objectList);
43
44  this->init();
45}
46
47
48Camera::Camera(const TiXmlElement* root)
49{
50  this->registerObject(this, Camera::_objectList);
51
52  if( root != NULL)
53    this->loadParams(root);
54
55  this->init();
56
57}
58
59
60/**
61 *  default destructor
62*/
63Camera::~Camera()
64{}
65
66void Camera::init()
67{
68  //this->setName("camera");
69  this->target = new CameraTarget();
70  this->target->masta=this;
71  this->subscribeEvent(ES_GAME, KeyMapper::PEV_VIEW0);
72  this->subscribeEvent(ES_GAME, KeyMapper::PEV_VIEW1);
73  this->subscribeEvent(ES_GAME, KeyMapper::PEV_VIEW2);
74  this->subscribeEvent(ES_GAME, KeyMapper::PEV_VIEW3);
75  this->subscribeEvent(ES_GAME, KeyMapper::PEV_VIEW4);
76  this->subscribeEvent(ES_GAME, KeyMapper::PEV_VIEW5);
77
78  //this->setFovy(90);
79  this->setAspectRatio(1.33f);
80  this->setClipRegion(.1, 10000);
81
82  this->viewTopFovy = 60;
83  this->viewNormalFovy = 90;
84  this->viewFrontFovy = 120;
85  this->viewRightFovy = 90;
86  this->viewLeftFovy = 90;
87
88  this->viewTopDistance = 70;
89  this->viewNormalDistance = 10;
90  this->viewFrontDistance = 4;
91  this->viewRightDistance = 10;
92  this->viewLeftDistance = 10;
93
94  this->setViewMode(Camera::ViewNormal);
95
96  this->setParentMode(PNODE_ALL);
97  this->eventHandling = true;
98
99  //add to track
100  if(this->entityTrack)
101    this->setParent(this->entityTrack->getTrackNode());
102}
103
104/**
105 *  focuses the Camera onto a Target
106 * @param target the new PNode the Camera should look at.
107*/
108void Camera::lookAt(PNode* target)
109{
110  this->target->setParentSoft(target,0.2);
111}
112
113/**
114 * @returns The PNode of the Target (from there you can get position and so on
115*/
116PNode* Camera::getTargetNode() const
117{
118  return (PNode*)this->target;
119}
120
121void Camera::setTargetNode(PNode* target)
122{
123  this->target->setParent(target);
124}
125
126/**
127 *  sets a new AspectRatio
128 * @param aspectRatio the new aspect ratio to set (width / height)
129*/
130void Camera::setAspectRatio(float aspectRatio)
131{
132  this->aspectRatio = aspectRatio;
133}
134
135/**
136 * Sets a new clipping region
137 * @param nearClip The near clip plane
138 * @param farClip The far clip plane
139*/
140void Camera::setClipRegion(float nearClip, float farClip)
141{
142  this->nearClip = nearClip;
143  this->farClip = farClip;
144}
145
146/**
147 *  sets the new VideoMode and initializes iteration to it.
148 * @param mode the mode to change to.
149*/
150void Camera::setViewMode(ViewMode mode)
151{
152  currentMode = mode;
153  switch (mode)
154  {
155    default:
156    case Camera::ViewNormal:
157    {
158      this->fovy = viewNormalFovy;
159      this->toFovy = viewNormalFovy;
160      //this->fovy = 60;
161      //this->toFovy = 60;
162      this->setRelCoorSoft(-2.0/3.0 * this->viewNormalDistance, 1.0/3.0 * this->viewNormalDistance, 0);
163      this->target->setRelCoorSoft(0,0,0);
164      break;
165    }
166    case Camera::ViewBehind:
167      break;
168    case Camera::ViewFront:
169    {
170      this->fovy = viewFrontFovy;
171      this->toFovy = viewFrontFovy;
172      this->setRelCoorSoft(this->viewFrontDistance, 0, 0, 5);
173      this->target->setRelCoorSoft(Vector(10,0,0), 5);
174      break;
175    }
176    case Camera::ViewLeft:
177    {
178      this->fovy = viewLeftFovy;
179      this->toFovy = viewLeftFovy;
180      this->setRelCoorSoft(0, 1, -viewLeftDistance, .5);
181      this->target->setRelCoorSoft(0,0,0);
182      break;
183    }
184    case Camera::ViewRight:
185    {
186      this->fovy = viewRightFovy;
187      this->toFovy = viewRightFovy;
188      this->setRelCoorSoft(Vector(0, 1, viewRightDistance), 0.5);
189      this->target->setRelCoorSoft(0,0,0);
190      break;
191    }
192    case Camera::ViewTop:
193    {
194      this->fovy= viewTopFovy;
195      this->toFovy = viewTopFovy;
196      this->setRelCoor(Vector(-0.05, this->viewTopDistance , 0));
197      this->target->setRelCoor(0,0,0);
198    }
199  }
200}
201
202
203/**
204 *  Updates the position of the camera.
205 * @param dt: The time that elapsed.
206*/
207void Camera::tick(float dt)
208{
209  //update frustum plane
210  this->viewVector = (this->target->getAbsCoor() - this->getAbsCoor()).getNormalized();
211  this->frustumPlane = Plane(this->viewVector, this->getAbsCoor() + this->viewVector * 0.1);
212  this->upVector =  this->getAbsDirV();
213
214  // iteration for fovy
215  float tmpFovy = (this->toFovy - this->fovy);
216  if (fabsf(tmpFovy) > 0.01)
217    this->fovy += tmpFovy * fabsf(dt);
218
219  if(this->entityTrack)
220    this->entityTrack->tick(dt);
221
222
223
224
225  //iterate(float dt, translate, target)
226  target->translate(dt);
227}
228
229
230/**
231 *  initialize rendering perspective according to this camera
232 *
233 * This is called immediately before the rendering cycle starts, it sets all global
234 * rendering options as well as the GL_PROJECTION matrix according to the camera.
235 */
236void Camera::apply ()
237{
238  // switching to Projection Matrix
239  glMatrixMode (GL_PROJECTION);
240  glLoadIdentity ();
241
242  gluPerspective(this->fovy,
243                 this->aspectRatio,
244                 this->nearClip,
245                 this->farClip);
246
247
248    // setting up the perspective
249  // speed-up feature
250  glMatrixMode (GL_MODELVIEW);
251  glLoadIdentity();
252
253
254}
255
256void Camera::project()
257{
258  Vector cameraPosition = this->getAbsCoor();
259  Vector targetPosition = this->target->getAbsCoor();
260
261        //Setting the Camera Eye, lookAt and up Vectors
262  gluLookAt(cameraPosition.x, cameraPosition.y, cameraPosition.z,
263            targetPosition.x, targetPosition.y, targetPosition.z,
264            this->upVector.x, this->upVector.y, this->upVector.z);
265}
266
267
268/**
269 *  processes an event
270 * @param event: the event to process
271*/
272void Camera::process(const Event &event)
273{
274  if (eventHandling == true)
275  {
276    if( event.type == KeyMapper::PEV_VIEW0)
277    {
278      this->setViewMode(Camera::ViewNormal);
279    }
280    else if( event.type == KeyMapper::PEV_VIEW1)
281    {
282      this->setViewMode(Camera::ViewBehind);
283    }
284    else if( event.type == KeyMapper::PEV_VIEW2)
285    {
286      this->setViewMode(Camera::ViewFront);
287    }
288    else if( event.type == KeyMapper::PEV_VIEW3)
289    {
290      this->setViewMode(Camera::ViewLeft);
291    }
292    else if( event.type == KeyMapper::PEV_VIEW4)
293    {
294      this->setViewMode(Camera::ViewRight);
295    }
296    else if( event.type == KeyMapper::PEV_VIEW5)
297    {
298      this->setViewMode(Camera::ViewTop);
299    }
300  }
301}
302
303
304void Camera::loadParams(const TiXmlElement* root)
305{
306  // Do the PNode loading stuff
307  WorldEntity::loadParams(root);
308
309  LoadParam(root, "viewTopFovy", this, Camera, setViewTopFovy);
310  LoadParam(root, "viewFrontFovy", this, Camera, setViewFrontFovy);
311  LoadParam(root, "viewLeftFovy", this, Camera, setViewLeftFovy);
312  LoadParam(root, "viewRightFovy", this, Camera, setViewRightFovy);
313  LoadParam(root, "viewBehindFovy", this, Camera, setViewBehindFovy);
314  LoadParam(root, "viewNormalFovy", this, Camera, setViewNormalFovy);
315
316  LoadParam(root, "viewTopDistance", this, Camera, setViewTopDistance);
317  LoadParam(root, "viewFrontDistance", this, Camera, setViewFrontDistance);
318  LoadParam(root, "viewLeftDistance", this, Camera, setViewLeftDistance);
319  LoadParam(root, "viewRightDistance", this, Camera, setViewRightDistance);
320  LoadParam(root, "viewBehindDistance", this, Camera, setViewBehindDistance);
321  LoadParam(root, "viewNormalDistance", this, Camera, setViewNormalDistance);
322}
323
324
325void Camera::setViewTopFovy(float fovy)
326{
327  this->viewTopFovy = fovy;
328}
329
330void Camera::setViewFrontFovy(float fovy)
331{
332  this->viewFrontFovy = fovy;
333}
334
335void Camera::setViewLeftFovy(float fovy)
336{
337  this->viewLeftFovy = fovy;
338}
339
340void Camera::setViewRightFovy(float fovy)
341{
342  this->viewRightFovy = fovy;
343}
344
345void Camera::setViewBehindFovy(float fovy)
346{
347  this->viewBehindFovy = fovy;
348}
349
350void Camera::setViewNormalFovy(float fovy)
351{
352  this->viewNormalFovy = fovy;
353}
354
355void Camera::setViewTopDistance(float Distance)
356{
357  this->viewTopDistance = Distance;
358}
359
360void Camera::setViewFrontDistance(float Distance)
361{
362  this->viewFrontDistance = Distance;
363}
364
365void Camera::setViewLeftDistance(float Distance)
366{
367  this->viewLeftDistance = Distance;
368}
369
370void Camera::setViewRightDistance(float Distance)
371{
372  this->viewRightDistance = Distance;
373}
374
375void Camera::setViewBehindDistance(float Distance)
376{
377  this->viewBehindDistance = Distance;
378}
379
380void Camera::setViewNormalDistance(float Distance)
381{
382  this->viewNormalDistance = Distance;
383}
384
385
386
387
388void Camera::glLookAt(float eyex, float eyey, float eyez, float centerx, float centery, float centerz, float upx, float upy, float upz)
389{
390  //Vector* eye=new Vector(eyex, eyey, eyez);
391  Vector* center=new Vector (centerx, centery, centerz);
392  Vector* up=new Vector(upx, upy, upz);
393
394  center->x-=eyex;
395  center->y-=eyey;
396  center->z-=eyez;
397
398  center->normalize();
399  up->normalize();
400  Vector* s = VectorProd(center, up);
401  Vector* u = VectorProd(s, center);
402  GLfloat Matrix[]={s->x, s->y, s->z, 0, u->x, u->y, u->z, 0, -center->x, -center->y, -center->z, 0, 0, 0, 0, 1};
403
404  glMultMatrixf(Matrix);
405  glTranslated(-eyex, -eyey, -eyez);
406  delete center;
407  delete up;
408  delete s;
409  delete u;
410
411}
412
413
414
415
416Vector* Camera::VectorProd(Vector* v1, Vector* v2)
417{
418Vector* temp= new Vector();
419temp->x=v1->y * v2->z - v1->z * v2->y;
420temp->y=v1->z * v2->x - v1->x * v2->z;
421temp->z=v1->x * v2->y - v1->y * v2->x;
422return temp;
423}
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438///////////////////
439// CAMERA-TARGET //
440///////////////////
441//REATE_FACTORY(CameraTarget);
442
443
444ObjectListDefinition(CameraTarget);
445
446
447CameraTarget::CameraTarget()
448{
449  this->registerObject(this, CameraTarget::_objectList);
450  //  this->setParentMode(PNODE_MOVEMENT);
451  this->speed=1;
452  translateTo.x=0;
453  translateTo.y=0;
454  translateTo.z=0;
455  rotateBy.x=0;
456  rotateBy.y=0;
457  rotateBy.z=0;
458  target=createStick();
459}
460
461
462void CameraTarget::detach()
463{
464  masta->setParentSoft(target);
465  masta->getTargetNode()->setParentSoft(target);
466}
467
468PNode* CameraTarget::createStick()
469{
470  return new Targets();
471}
472
473
474void CameraTarget::atach(PNode* object)
475{
476  masta->setParentSoft(object);
477  masta->getTargetNode()->setParentSoft(object);
478}
479
480
481
482
483Vector CameraTarget::iterate(float dt, const Vector* Target, const Vector* cam)
484{
485
486
487  Vector tmpVec;
488  tmpVec= (*Target - *cam);
489  tmpVec.normalize();
490  return  tmpVec;
491
492}
493
494
495void CameraTarget::translate(float dt)
496{
497  if (fabs(translateTo.len()  - (target->getAbsCoor()).len()) >= 11 )
498 {
499   printf("translate\n");
500   Vector tmpVec= iterate(dt,  &translateTo,  &(masta->getAbsCoor()));
501   target->shiftCoor(speed*tmpVec.x, speed*tmpVec.y, speed*tmpVec.z);
502  }
503}
504
505Vector * CameraTarget::rotate(Vector* newPos, float speed)
506{
507
508}
509
510void CameraTarget::jump(float x, float y, float z)
511{
512target->setAbsCoor(x,y,z);
513}
514
515
516void CameraTarget::trans(float x, float y, float z)
517{
518  Vector tmpVec=Vector(x,y,z);
519  if( this->getParent())
520    this->getParent()->setRelCoor(this->getParent()->getRelCoor());
521  translateNow(&tmpVec);
522}
523
524void CameraTarget::translateNow(Vector* vec)
525{
526translateTo=*vec;
527}
528
529void CameraTarget::changeSpeed(float speed)
530{
531  if (speed!=0)
532this->speed=speed;
533  return;
534}
535
536
537bool CameraTarget::isDone()
538{
539  if (fabs(translateTo.len()  - (target->getAbsCoor()).len()) >= 11 )
540    return 0;
541  else
542    return 1;
543}
Note: See TracBrowser for help on using the repository browser.