khanat-opennel-code/code/ryzom/client/src/interfaces_manager/osd.h
2010-08-20 13:27:17 +02:00

463 lines
12 KiB
C++

// Ryzom - MMORPG Framework <http://dev.ryzom.com/projects/ryzom/>
// Copyright (C) 2010 Winch Gate Property Limited
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero 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 Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifndef CL_OSD_H
#define CL_OSD_H
/////////////
// Include //
/////////////
// Misc
#include "nel/misc/types_nl.h"
#include "nel/misc/ucstring.h"
#include "nel/misc/rgba.h"
// Client
#include "control.h"
#include "pen.h"
// Std
#include <map>
#include <fstream>
///////////
// Using //
///////////
using NLMISC::CRGBA;
using std::map;
using std::ifstream;
/**
* Class to manage an OSD (On Screen Display = Kind of window) for the interfaces.
* \author Guillaume PUZIN
* \author Nevrax France
* \date 2001
*/
class COSD
{
public:
enum ECursor
{
Cur_None = 0,
Cur_Move, // Move
Cur_Resize, // Resize
Cur_Resize_TL, // Resize Top Left
Cur_Resize_T, // Resize Top
Cur_Resize_TR, // Resize Top Right
Cur_Resize_R, // Resize Right
Cur_Resize_BR, // Resize Bottom Right
Cur_Resize_B, // Resize Bottom
Cur_Resize_BL, // Resize Bottom Left
Cur_Resize_L, // Resize Left
};
enum TMode
{
none = 0,
selected,
resizable,
movable,
locked,
blocked
};
enum TResize
{
no_resize = 0,
resize_B,
resize_T,
resize_R,
resize_L,
resize_BL,
resize_TL,
resize_BR,
resize_TR,
resize_move
};
enum TBG // BG = Background.
{
BG_none = 0, // NO BG.
BG_plain, // BG is only made with 1 color (RGBA).
BG_stretch // BG is a Bitmap and 1 color (RGBA).
};
enum TTB // TB = Title Bar.
{
TB_none = 0, // NO TB.
TB_plain, // TB is only made with 1 color (RGBA).
TB_stretch // TB is a Bitmap and 1 color (RGBA).
};
private:
typedef std::map<uint, CControl *> TMapControls;
typedef std::list<CControl *> TListControl;
/// Map to find a control with the Id.
TMapControls _Controls;
/// The list of control in order to display.
TListControl _Children;
/// Initialize the button (1 function called for all constructors -> easier).
inline void init(uint id,float x, float y, float x_pixel, float y_pixel, float w, float h, float w_pixel, float h_pixel, float minWidth, float minHeight, bool popUp = false);
void getText(uint idCtrl);
void getCapture(uint idCtrl);
void getButton(uint idCtrl);
void getRadioButton(uint idCtrl);
void getRadioController(uint idCtrl);
void getBitmap(uint idCtrl);
void getList(uint idCtrl);
void getMultiList(uint idCtrl);
void getChatBox(uint idCtrl);
void getChatInput(uint idCtrl);
void getChoiceList(uint idCtrl);
void getCandidateList(uint idCtrl);
void getHorizontalList(uint idCtrl);
void getControlList(uint idCtrl);
void getSpellList(uint idCtrl);
void getProgressBar(uint idCtrl);
void getCastingBar(uint idCtrl);
void getBrickControl(uint idCtrl);
/// Resize the Left border of the OSD.
void resizeL(float x, float y);
/// Resize the Right border of the OSD.
void resizeR(float x, float y);
/// Resize the Bottom border of the OSD.
void resizeB(float x, float y);
/// Resize the Top border of the OSD.
void resizeT(float x, float y);
/// Move the OSD.
void move(float x, float y);
/// Function to test if a coordinate is in the rect.
bool testInRect(float x, float y, float rectX0, float rectY0, float rectX1, float rectY1);
/// Calculate a position according to the origin.
void calculatePos(float &x, float &y, CControl::THotSpot origin);
/// Calculate the Display X, Y, Width, Height.
void calculateDisplay();
/// Function to draw the background according to the mode.
void drawBG();
/// Function to draw the Title Bar according to the mode.
void drawTB();
/// Draw the resize borders.
void drawBorders(float bSizeW, float bSizeH, float x0, float y0, float x1, float y1, const CRGBA &color);
/// Draw a text with all informations needed.
void drawText(float x, float y, const ucstring &text, const CPen &pen);
/// Test the mode of the OSD.
void testMode(float x, float y, float rectX0, float rectY0, float rectX1, float rectY1);
/// Determine the Resize Mode.
bool resizeMode(float x, float y);
protected:
/// the 'ID' fo the OSD (as defined for the interface manager)
uint _Id;
/// boolean indicating if the OSD is a 'pop-up' window, in this case, a click outside the window close that window
bool _PopUp;
/// Position of the OSD (between 0-1).
float _X;
float _Y;
/// Position of the OSD (in Pixel).
float _X_Pixel;
float _Y_Pixel;
/// Minimum values for window size
float _W_Min;
float _H_Min;
/// Display Position of the Control (between 0-1).
float _X_Display;
float _Y_Display;
/// Width and Height (between 0-1).
float _W;
float _H;
/// Width and Height (in pixel).
float _W_Pixel;
float _H_Pixel;
/// Display Width and Height of the Control (between 0-1).
float _W_Display;
float _H_Display;
/// Variables to know the offset between the click position and the OSD borders.
float _OffsetX;
float _OffsetY;
float _OffsetW;
float _OffsetH;
/// Is the OSD Visible.
bool _Show;
/** \name OSD
* Variables to manage the OSD.
*/
//@{
/// How to display the OSD.
TMode _OSD_Mode;
/// Name of the OSD.
ucstring _OSD_Name;
/// Function called each update (every frame in most case).
uint _OSD_Update_Func;
//@}
/** \name Background
* Variables to manage the background of the OSD.
*/
//@{
/// Display mode for the background.
TBG _BG_Mode;
/// Id of the texture for the background.
uint _BG;
/// Color of the Background.
CRGBA _BG_Color;
//@}
/** \name Title Bar
* Variables to manage the Title Bar of the OSD.
*/
//@{
/// Display mode for the Title Bar.
TTB _TB_Mode;
/// Id of the texture for the Title BAr.
uint _TB;
/// Color of the Title Bar.
CRGBA _TB_Color;
/// Height of the Title Bar (in Pixel).
float _TB_H;
/// Display Height of the Title Bar.
float _TB_H_Display;
/// Pen of the Title Bar.
CPen _TB_Pen;
//@}
/** \name HighLight
* Variables to manage the HighLight of the OSD.
*/
//@{
/// Color of the HighLight.
CRGBA _HL_Color;
/// HighLight Size (in Pixel).
float _HL_Size;
/// HighLight Size for the width (between 0-1).
float _HL_W;
/// HighLight Size for the height (between 0-1).
float _HL_H;
//@}
/** \name Resize
* Variables to manage the Resize of the OSD.
*/
//@{
/// Resize Mode.
TResize _RS_Mode;
/// Resize borders Color
CRGBA _RS_Color;
/// Resize size (in pixel).
float _RS_Size;
/// Resize Size for the width (between 0-1).
float _RS_W;
/// Resize Size for the height (between 0-1).
float _RS_H;
//@}
ECursor _Cursor;
public:
/// Constructor
COSD(bool popUp = false);
COSD(uint Id, float x, float y, float x_pixel, float y_pixel, float w, float h, float w_pixel, float h_pixel, float minWidth, float minHeight, bool popUp = false);
/// Destructor
~COSD();
/// The OSD size has changed -> resize controls.
void resize(uint32 width, uint32 height);
/// Update the OSD (for timers, etc.).
bool update(float x, float y, bool fullUse);
/// Display the OSD.
void display();
/**
* Return the cursor used by the OSD at the moment.
* \return ECursor : 'Cur_None' if no cursor needed for the OSD.
* \warning This method should be called after the update one to be up to date.
*/
ECursor cursor();
/// Manage the mouse click.
void click(float x, float y, bool &taken);
/// Manage the mouse right click.
void clickRight(float x, float y, bool &taken);
/// Add a control.
void addChild(uint idCtrl, CControl *ctrl);
/// Delete a control by the Id.
void delChild(uint idCtrl);
/// remove ctrl from children list (but not from control list)
void removeFromChildren(uint idCtrl);
/// Return the pointer of the control "id" or 0 if the control "id" doesn't exit.
CControl *getCtrl(uint id);
/// Load the OSD script.
void open(ifstream &file);
/** \name SHOW/HIDE
* Functions to show/hide the OSD.
*/
//@{
/**
* This function return if the OSD is visible or not .
* \return bool : true if the OSD is visible.
*/
inline bool show() const {return _Show;}
/**
* This function set if the OSD is visible or not .
* \param s : false to hide the OSD.
*/
inline void show(bool s) {_Show = s;}
//@}
/** \name OSD
* Functions to manage the OSD.
*/
//@{
/// Change the OSD Position (between O-1).
void osdSetPosition(float x, float y);
/// Return the OSD Position (between O-1).
void osdGetPosition(float &x, float &y) const ;
/// Change the OSD Size (in Pixel).
void osdSetSize(float w, float h);
/// Return the OSD Size (in Pixel).
void osdGetSize(float &w, float &h) const ;
/// Change the OSD Mode (locked, resize, selected, etc.)
void osdMode(TMode osdMode);
/// Return the current OSD Mode.
TMode osdMode() const ;
/// Change the OSD Name.
void osdName(const ucstring &osdName);
/// Return the OSD Name.
ucstring osdName() const;
/// Set the update Function.
void osdUpdateFunc(uint osdUpdateFunc);
/// Get the update Function.
uint osdUpdateFunc() const ;
uint getId() const { return _Id; }
//@}
/** \name Background
* Functions to manage the background.
*/
//@{
/// Set the Background display mode.
void bgMode(TBG mode);
/// Get the Background display mode.
TBG bgMode() const ;
/// Set the texture Id for the Background.
void bg(uint b);
/// Get background Id.
uint bg() const ;
/// Set the Background RGBA.
void bgColor(const CRGBA &bRGBA);
/// Get the background RGBA.
CRGBA bgColor() const ;
//@}
/** \name Title Bar
* Functions to manage the Title Bar.
*/
//@{
/// Set the Title Bar display mode.
void tbMode(TTB mode);
/// Get the Title Bar display mode.
TTB tbMode() const ;
/// Set the texture Id for the Title Bar.
void tb(uint t);
/// Get Title Bar Id.
uint tb() const ;
/// Set the Title Bar RGBA.
void tbColor(const CRGBA &tRGBA);
/// Get the Title Bar RGBA.
CRGBA tbColor() const ;
/// Set Title Bar Height (in Pixel)
void tbHeight(float height);
/// Get Title Bar Height (in Pixel)
float tbHeight() const;
/// Set the Pen for the Title Bar.
void tbPen(const CPen &pen);
/// Get the Pen of the Title Bar.
CPen tbPen() const ;
//@}
/** \name HighLight
* Functions to manage the HighLight.
*/
//@{
/// Set the HighLight Color.
void hlColor(const CRGBA &hlColor);
/// Get the HighLight Color.
CRGBA hlColor() const ;
/// Set the HighLight Size (in Pixel).
void hlSize(float hlSize);
/// Get the HighLight Size (in Pixel).
float hlSize() const ;
//@}
/** \name Resize
* Functions to manage the Resize of the OSD.
*/
//@{
/// Set the Resize Mode.
void rsMode(TResize rsMode);
/// Get the Resize Mode.
TResize rsMode() const ;
/// Set Resize borders Color
void rsColor(CRGBA rsColor);
/// Get Resize borders Color
CRGBA rsColor() const ;
/// Set Resize size (in pixel).
void rsSize(float rsSize);
/// Get Resize size (in pixel).
float rsSize() const ;
//@}
};
#endif // CL_OSD_H
/* End of osd.h */