f314c1ff2a
- move it to separate class, so that it can be displayed in Overworld too - add a possibility to scale the interface (atm. only in config.xml) - touch steering buttons are created only for single player races I removed unused drawEnergyMeter function from Overworld GUI. The reason was that I use this function from race_gui.cpp for nitro button and this function in overworld breaks it. And still the proper drawEnergyMeter function is available in race_gui.cpp and can be moved to RaceGuiBase if it will be needed in Overworld in future. I moved the font size computation to the top of constructor because I use it to check available space for minimap.
251 lines
8.9 KiB
C++
251 lines
8.9 KiB
C++
//
|
|
// SuperTuxKart - a fun racing game with go-kart
|
|
// Copyright (C) 2010-2015 Joerg Henrichs
|
|
//
|
|
// This program is free software; you can redistribute it and/or
|
|
// modify it under the terms of the GNU General Public License
|
|
// as published by the Free Software Foundation; either version 3
|
|
// of the License, or (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program; if not, write to the Free Software
|
|
// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
#ifndef HEADER_RACE_GUI_BASE_HPP
|
|
#define HEADER_RACE_GUI_BASE_HPP
|
|
|
|
#include <vector>
|
|
|
|
#include <irrString.h>
|
|
#include <vector2d.h>
|
|
#include <rect.h>
|
|
#include <dimension2d.h>
|
|
#include <SColor.h>
|
|
namespace irr
|
|
{
|
|
namespace video { class ITexture; struct S3DVertex; }
|
|
namespace scene { class IAnimatedMeshSceneNode; }
|
|
}
|
|
using namespace irr;
|
|
|
|
#include "utils/vec3.hpp"
|
|
|
|
class AbstractKart;
|
|
class Camera;
|
|
class Material;
|
|
class Referee;
|
|
class RaceGUIMultitouch;
|
|
|
|
/**
|
|
* \brief An abstract base class for the two race guis (race_gui and
|
|
* race_result gui)
|
|
* \ingroup states_screens
|
|
*/
|
|
class RaceGUIBase
|
|
{
|
|
public:
|
|
/**
|
|
* Used to display the list of karts and their times or
|
|
* whatever other info is relevant to the current mode.
|
|
*/
|
|
struct KartIconDisplayInfo
|
|
{
|
|
/** Text to display next to icon, if any. */
|
|
core::stringw m_text;
|
|
|
|
/** Text color, if any text. */
|
|
video::SColor m_color;
|
|
|
|
/** If this kart has a special title, e.g. "leader" in follow-the-leader. */
|
|
core::stringw special_title;
|
|
|
|
/** Current lap of this kart, or -1 if irrelevant. */
|
|
int lap;
|
|
}; // KartIconDisplayInfo
|
|
|
|
private:
|
|
/** True if unimportant messags (like item messages) should not
|
|
* be displayed. */
|
|
bool m_ignore_unimportant_messages;
|
|
|
|
class TimedMessage
|
|
{
|
|
public:
|
|
/** Message to display. */
|
|
irr::core::stringw m_message;
|
|
/** Time remaining before removing this message from screen. */
|
|
float m_remaining_time;
|
|
/** Color of message. */
|
|
video::SColor m_color;
|
|
|
|
const AbstractKart *m_kart;
|
|
/** Important msgs are displayed in the middle of the screen. */
|
|
bool m_important;
|
|
bool m_big_font;
|
|
|
|
// -----------------------------------------------------
|
|
// std::vector needs standard copy-ctor and std-assignment op.
|
|
// let compiler create defaults .. they'll do the job, no
|
|
// deep copies here ..
|
|
TimedMessage(const irr::core::stringw &message,
|
|
const AbstractKart *kart, float time,
|
|
const video::SColor &color, const bool important,
|
|
bool big_font)
|
|
{
|
|
m_message = message;
|
|
m_kart = kart;
|
|
m_remaining_time = ( time < 0.0f ) ? -1.0f : time;
|
|
m_color = color;
|
|
m_important = important;
|
|
m_big_font = big_font;
|
|
} // TimedMessage
|
|
// -----------------------------------------------------
|
|
// in follow leader the clock counts backwards
|
|
bool done(const float dt)
|
|
{
|
|
m_remaining_time -= dt;
|
|
return m_remaining_time < 0;
|
|
} // done
|
|
}; // TimedMessage
|
|
// ---------------------------------------------------------
|
|
|
|
typedef std::vector<TimedMessage> AllMessageType;
|
|
AllMessageType m_messages;
|
|
int m_small_font_max_height;
|
|
|
|
/** Used to display messages without overlapping */
|
|
int m_max_font_height;
|
|
|
|
/** Musical notes icon (for music description and credits) */
|
|
Material *m_music_icon;
|
|
|
|
/** Translated strings 'ready', 'set', 'go'. */
|
|
core::stringw m_string_ready, m_string_set, m_string_go, m_string_goal;
|
|
|
|
/** The position of the referee for all karts. */
|
|
std::vector<Vec3> m_referee_pos;
|
|
|
|
/** The actual rotation to use for the referee for each kart. */
|
|
std::vector<Vec3> m_referee_rotation;
|
|
|
|
/** The height of the referee. This is used to make the referee fly
|
|
* into view. This is the same Y-offset for all karts, so only a
|
|
* single value needs to be used. */
|
|
float m_referee_height;
|
|
|
|
/** The referee scene node. */
|
|
Referee *m_referee;
|
|
|
|
|
|
protected:
|
|
/** Material for the 'plunger in the face' texture. */
|
|
Material *m_plunger_face;
|
|
|
|
/** State of the plunger: From the 'init' states the plunger switches
|
|
* between two slow moving states ('shakily moving') till the end of
|
|
* the plunger time is nearly reached, then it goes to a very fast
|
|
* moving state ('plunger blown off'). */
|
|
enum PlungerState {PLUNGER_STATE_INIT, PLUNGER_STATE_SLOW_1,
|
|
PLUNGER_STATE_SLOW_2, PLUNGER_STATE_FAST}
|
|
m_plunger_state;
|
|
|
|
/** How long the plunger should stay in the current state. */
|
|
float m_plunger_move_time;
|
|
|
|
/** Offset of the plunger. */
|
|
core::vector2di m_plunger_offset;
|
|
|
|
/* Speed of the plunger. This gets changed depending on state (not moving,
|
|
* slow moving, fast moving). */
|
|
core::vector2df m_plunger_speed;
|
|
|
|
/** The size of a single marker in pixels, must be a power of 2. */
|
|
//int m_marker_rendered_size;
|
|
|
|
/** A texture with all mini dots to be displayed in the minimap for all karts. */
|
|
//video::ITexture *m_marker;
|
|
video::ITexture *m_gauge_empty;
|
|
/** Default texture for nitro gauge. */
|
|
video::ITexture *m_gauge_full;
|
|
/** Highlight gauge, used when a kart uses nitro. */
|
|
video::ITexture *m_gauge_full_bright;
|
|
|
|
video::ITexture *m_gauge_goal;
|
|
|
|
/** The frame around player karts in the mini map. */
|
|
Material *m_icons_frame;
|
|
|
|
RaceGUIMultitouch* m_multitouch_gui;
|
|
|
|
void cleanupMessages(const float dt);
|
|
//void createMarkerTexture();
|
|
void createRegularPolygon(unsigned int n, float radius,
|
|
const core::vector2df ¢er,
|
|
const video::SColor &color,
|
|
video::S3DVertex *v, unsigned short int *index);
|
|
void drawAllMessages (const AbstractKart* kart,
|
|
const core::recti &viewport,
|
|
const core::vector2df &scaling);
|
|
void drawPowerupIcons (const AbstractKart* kart,
|
|
const core::recti &viewport,
|
|
const core::vector2df &scaling);
|
|
void drawGlobalMusicDescription();
|
|
void drawGlobalReadySetGo();
|
|
void drawGlobalGoal();
|
|
void drawPlungerInFace(const Camera *camera, float dt);
|
|
/** Instructs the base gui to ignore unimportant messages (like
|
|
* item messages).
|
|
*/
|
|
void ignoreUnimportantMessages() { m_ignore_unimportant_messages = true; }
|
|
|
|
/** Distance on track to begin showing overlap in drawGlobalPlayerIcons */
|
|
float m_dist_show_overlap;///can be zero
|
|
float m_icons_inertia;///can be zero
|
|
|
|
/** previous position of icons */
|
|
std::vector< core::vector2d<s32> > m_previous_icons_position;
|
|
|
|
/** This vector is passed to world to be filled with the current
|
|
* race data information. */
|
|
std::vector<KartIconDisplayInfo> m_kart_display_infos;
|
|
|
|
public:
|
|
|
|
bool m_enabled;
|
|
|
|
RaceGUIBase();
|
|
virtual ~RaceGUIBase();
|
|
virtual void renderGlobal(float dt);
|
|
virtual void init();
|
|
virtual void reset();
|
|
virtual void renderPlayerView(const Camera *camera, float dt);
|
|
virtual void addMessage(const irr::core::stringw &m,
|
|
const AbstractKart *kart, float time,
|
|
const video::SColor &color=
|
|
video::SColor(255, 255, 0, 255),
|
|
bool important=true,
|
|
bool big_font=false);
|
|
virtual void update(float dt);
|
|
virtual void preRenderCallback(const Camera *camera);
|
|
// ------------------------------------------------------------------------
|
|
/** Returns the size of the texture on which to render the minimap to. */
|
|
virtual const core::dimension2du
|
|
getMiniMapSize() const = 0;
|
|
// ------------------------------------------------------------------------
|
|
virtual void clearAllMessages() { m_messages.clear(); }
|
|
|
|
void drawGlobalPlayerIcons(int bottom_margin);
|
|
|
|
virtual void drawEnergyMeter(int x, int y, const AbstractKart *kart,
|
|
const core::recti &viewport,
|
|
const core::vector2df &scaling) {};
|
|
|
|
}; // RaceGUIBase
|
|
|
|
#endif
|