Project::OSiRiON - Git repositories
Project::OSiRiON
News . About . Screenshots . Downloads . Forum . Wiki . Tracker . Git
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/view.cc')
-rw-r--r--src/client/view.cc171
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()) {