source: flair-src/trunk/lib/FlairSimulator/src/GenericObject.cpp@ 274

Last change on this file since 274 was 158, checked in by Sanahuja Guillaume, 8 years ago

corrected simu/device id for sensors

File size: 2.0 KB
Line 
1// %flair:license{
2// This file is part of the Flair framework distributed under the
3// CECILL-C License, Version 1.0.
4// %flair:license}
5// created: 2013/03/25
6// filename: GenericObject.cpp
7//
8// author: Cesar Richard
9// Copyright Heudiasyc UMR UTC/CNRS 7253
10//
11// version: $Id: $
12//
13// purpose: classe definissant un modele a simuler
14//
15/*********************************************************************/
16
17#ifdef GL
18#include "GenericObject.h"
19#include "Simulator.h"
20#include "Simulator_impl.h"
21#include "Gui.h"
22
23#include "Quaternion.h"
24#include "Euler.h"
25#include <ISceneManager.h>
26#include <IMeshSceneNode.h>
27
28using namespace irr;
29using namespace video;
30using namespace scene;
31using namespace core;
32
33using namespace flair::core;
34using namespace flair::simulator;
35
36namespace flair {
37namespace simulator {
38
39GenericObject::GenericObject(IMesh *mesh)
40{
41 meshSceneNode=getGui()->getSceneManager()->addMeshSceneNode(mesh);
42
43 selector = getGui()->getSceneManager()->createTriangleSelector(mesh, meshSceneNode);
44 meshSceneNode->setTriangleSelector(selector);
45
46 meshSceneNode->setMaterialFlag(EMF_LIGHTING, false);
47
48 getSimulator()->pimpl_->objects.push_back(this);
49}
50
51GenericObject::~GenericObject() {}
52
53ITriangleSelector *GenericObject::TriangleSelector(void) { return selector; }
54
55void GenericObject::setScale(float value) {
56 meshSceneNode->setScale(vector3df(value, value, value));
57}
58
59void GenericObject::setScale(const vector3df& scale) {
60 meshSceneNode->setScale(scale);
61}
62
63void GenericObject::setPosition(const vector3df& pos) {
64 meshSceneNode->setPosition(ToIrrlichtCoordinates(pos));
65}
66
67void GenericObject::setRotation(const vector3df& rotation) {
68 Euler eulerA(rotation.X, rotation.Y, rotation.Z);
69 Euler eulerB;
70 Quaternion quatA, quatB;
71 eulerA.ToQuaternion(quatA);
72 quatB = ToIrrlichtOrientation(quatA);
73 quatB.ToEuler(eulerB);
74
75 meshSceneNode->setRotation(Euler::ToDegree(1) *
76 vector3df(eulerB.roll, eulerB.pitch, eulerB.yaw));
77}
78
79} // end namespace simulator
80} // end namespace flair
81#endif
Note: See TracBrowser for help on using the repository browser.