Project::OSiRiON - Git repositories
Project::OSiRiON
News . About . Screenshots . Downloads . Forum . Wiki . Tracker . Git
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStijn Buys <ingar@osirion.org>2008-12-21 12:12:53 +0000
committerStijn Buys <ingar@osirion.org>2008-12-21 12:12:53 +0000
commitaad0913d91fc3b682deddb5a5f8380d1475174f5 (patch)
tree5b1489a36e7640805058d99db0a0c44447949f4a /src/render/draw.cc
parentda4b99de2cf290ccdd22587a8c50aeeadd5ac957 (diff)
improved func_rotate
Diffstat (limited to 'src/render/draw.cc')
-rw-r--r--src/render/draw.cc13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/render/draw.cc b/src/render/draw.cc
index afff831..e094a44 100644
--- a/src/render/draw.cc
+++ b/src/render/draw.cc
@@ -582,8 +582,17 @@ void draw_model_fragments(core::Entity *entity)
if (group->type() == model::FragmentGroup::Rotate) {
gl::push();
gl::translate(group->location());
- float angle = math::degrees360f(core::application()->time() * 90.0f);
- gl::rotate(angle, math::Vector3f::Xaxis());
+
+ float rotation_angle = math::degrees360f(core::application()->time() * group->speed());
+
+ if (group->angle() == model::ANGLEUP) {
+ gl::rotate(rotation_angle, math::Vector3f::Zaxis());
+ } else if (group->angle() == model::ANGLEDOWN) {
+ gl::rotate(-rotation_angle, math::Vector3f::Zaxis());
+ } else {
+ gl::rotate(rotation_angle, math::Vector3f::Xaxis());
+ }
+
gl::translate(group->location()* -1.0f);
}