diff options
Diffstat (limited to 'src/client/view.cc')
-rw-r--r-- | src/client/view.cc | 171 |
1 files changed, 95 insertions, 76 deletions
diff --git a/src/client/view.cc b/src/client/view.cc index 03ce42b..2667938 100644 --- a/src/client/view.cc +++ b/src/client/view.cc @@ -22,6 +22,7 @@ #include "core/core.h" #include "math/mathlib.h" #include "sys/sys.h" +#include "ui/ui.h" namespace client { @@ -578,7 +579,7 @@ void draw_status() void draw_cursor() { - if (!core::localcontrol() || console()->visible()) + if (console()->visible()) return; float angle = 0; @@ -588,83 +589,92 @@ void draw_cursor() bool cursor_animated = false; math::Color color(1.0, 0.5); - if (render::Camera::mode() == render::Camera::Overview) { - render::Textures::bind("bitmaps/pointers/aim"); + if(ui::root()->active()) { + render::Textures::bind("bitmaps/pointers/pointer"); - } else { - // draw center cursor in Cockpit and Track mode - if ((input::mouse_control || input::joystick_control) && - (render::Camera::mode() == render::Camera::Cockpit || render::Camera::mode() == render::Camera::Track)) { - - if (ui_pointercolor) { - std::stringstream colorstr(ui_pointercolor->str()); - colorstr >> color; - } - - render::Textures::bind("bitmaps/pointers/center"); - float cx = (video::width - pointer_size) /2; - float cy = (video::height - pointer_size) /2; - - render::gl::color(color); - render::gl::begin(render::gl::Quads); - - glTexCoord2f(0,0 ); - render::gl::vertex(cx,cy,0.0f); - - glTexCoord2f(1, 0); - render::gl::vertex(cx+pointer_size, cy, 0.0f); - - glTexCoord2f(1, 1); - render::gl::vertex(cx+pointer_size, cy+pointer_size, 0.0f); - - glTexCoord2f(0, 1); - render::gl::vertex(cx, cy+pointer_size, 0.0f); - - render::gl::end(); - } - - if (targets::hover()) { - - if (ui_pointerhovercolor) { - std::stringstream colorstr(ui_pointerhovercolor->str()); - colorstr >> color; - } - render::Textures::bind("bitmaps/pointers/target"); - - cursor_animated = true; - - if (input::joystick_lastmoved_time() > input::mouse_lastmoved_time()) { - x = (video::width - pointer_size) /2; - y = (video::height - pointer_size) /2; - } - - } else if (input::mouse_control) { - - if (ui_pointercolor) { - std::stringstream colorstr(ui_pointercolor->str()); - colorstr >> color; - } - - render::Textures::bind("bitmaps/pointers/control"); - - if (!input::mouse_deadzone) { - x = input::mouse_position_x() - (pointer_size /2); - y = input::mouse_position_y() - (pointer_size /2); - - } else { - x = (video::width - pointer_size) /2; - y = (video::height - pointer_size) /2; - } + } else if (core::localcontrol()) { + if (render::Camera::mode() == render::Camera::Overview) { + render::Textures::bind("bitmaps/pointers/aim"); + } else { - if ((input::joystick_lastmoved_time() > input::mouse_lastmoved_time()) && (render::Camera::mode() == render::Camera::Cockpit || render::Camera::mode() == render::Camera::Track)) { - color.assign(1.0, 0.0); + // draw center cursor in Cockpit and Track mode + if ((input::mouse_control || input::joystick_control) && + (render::Camera::mode() == render::Camera::Cockpit || render::Camera::mode() == render::Camera::Track)) { + + if (ui_pointercolor) { + std::stringstream colorstr(ui_pointercolor->str()); + colorstr >> color; + } + + render::Textures::bind("bitmaps/pointers/center"); + float cx = (video::width - pointer_size) /2; + float cy = (video::height - pointer_size) /2; + + render::gl::color(color); + render::gl::begin(render::gl::Quads); + + glTexCoord2f(0,0 ); + render::gl::vertex(cx,cy,0.0f); + + glTexCoord2f(1, 0); + render::gl::vertex(cx+pointer_size, cy, 0.0f); + + glTexCoord2f(1, 1); + render::gl::vertex(cx+pointer_size, cy+pointer_size, 0.0f); + + glTexCoord2f(0, 1); + render::gl::vertex(cx, cy+pointer_size, 0.0f); + + render::gl::end(); + } + + if (targets::hover()) { + + if (ui_pointerhovercolor) { + std::stringstream colorstr(ui_pointerhovercolor->str()); + colorstr >> color; + } + render::Textures::bind("bitmaps/pointers/target"); + + cursor_animated = true; + + if (input::joystick_lastmoved_time() > input::mouse_lastmoved_time()) { + x = (video::width - pointer_size) /2; + y = (video::height - pointer_size) /2; + } + + } else if (input::mouse_control) { + + if (ui_pointercolor) { + std::stringstream colorstr(ui_pointercolor->str()); + colorstr >> color; + } + + render::Textures::bind("bitmaps/pointers/control"); + + if (!input::mouse_deadzone) { + x = input::mouse_position_x() - (pointer_size /2); + y = input::mouse_position_y() - (pointer_size /2); + + } else { + x = (video::width - pointer_size) /2; + y = (video::height - pointer_size) /2; + } + } else { - color.assign(1.0, 0.5); + if ((input::joystick_lastmoved_time() > input::mouse_lastmoved_time()) && (render::Camera::mode() == render::Camera::Cockpit || render::Camera::mode() == render::Camera::Track)) { + color.assign(1.0, 0.0); + } else { + color.assign(1.0, 0.5); + } + render::Textures::bind("bitmaps/pointers/aim"); } - render::Textures::bind("bitmaps/pointers/aim"); + } + } else { + return; } if (cursor_animated) { @@ -772,13 +782,16 @@ void frame(float seconds) if (core::application()->load("intro")) { current_zone = 0; core::application()->connect(""); - if (!console()->visible()) - console()->toggle(); } + } else { + /* + if (!core::game()->interactive() && !ui::root()->active()) { + ui::root()->show_window("main"); + } + */ } if (core::application()->connected() && core::game()->serverframetime()) { - if (core::localplayer()->zone() != current_zone) { if (current_zone) clear_zone(current_zone); @@ -799,14 +812,20 @@ void frame(float seconds) // switch to orthographic projection to draw the GUI gl::matrixmode(GL_PROJECTION); gl::loadidentity(); - glOrtho(0, video::width, video::height, 0, -1024.0f, 1024.0f); + glOrtho(0, video::width, video::height, 0, -16.0f, 16.0f); gl::matrixmode(GL_MODELVIEW); gl::loadidentity(); + // draw the user interface + gl::color(1.0f, 1.0f, 1.0f, 1.0f); + gl::disable(GL_TEXTURE_2D); + + ui::frame(); + + // draw the hud - TODO move as much as possible into ui:: gl::enable(GL_BLEND); gl::enable(GL_TEXTURE_2D); - gl::color(1.0f, 1.0f, 1.0f, 1.0f); if (!core::application()->connected()) { |