30b56d2ec5
git-svn-id: http://svn.code.sf.net/p/irrlicht/code/trunk@643 dfc29bdd-3216-0410-991c-e03cc46cb475
453 lines
14 KiB
C++
453 lines
14 KiB
C++
// Copyright (C) 2002-2007 Nikolaus Gebhardt
|
|
// This file is part of the "Irrlicht Engine".
|
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
|
|
|
#ifndef __I_GUI_SKIN_H_INCLUDED__
|
|
#define __I_GUI_SKIN_H_INCLUDED__
|
|
|
|
#include "IAttributeExchangingObject.h"
|
|
#include "SColor.h"
|
|
#include "rect.h"
|
|
|
|
namespace irr
|
|
{
|
|
namespace gui
|
|
{
|
|
class IGUIFont;
|
|
class IGUISpriteBank;
|
|
class IGUIElement;
|
|
|
|
//! Enumeration of available default skins.
|
|
/** To set one of the skins, use the following code, for example to set
|
|
the Windows classic skin:
|
|
\code
|
|
gui::IGUISkin* newskin = environment->createSkin(gui::EGST_WINDOWS_CLASSIC);
|
|
environment->setSkin(newskin);
|
|
newskin->drop();
|
|
\endcode
|
|
*/
|
|
enum EGUI_SKIN_TYPE
|
|
{
|
|
//! Default windows look and feel
|
|
EGST_WINDOWS_CLASSIC=0,
|
|
//! Like EGST_WINDOWS_CLASSIC, but with metallic shaded windows and buttons
|
|
EGST_WINDOWS_METALLIC,
|
|
//! Burning's skin
|
|
EGST_BURNING_SKIN,
|
|
|
|
//! An unknown skin, not serializable at present
|
|
EGST_UNKNOWN
|
|
};
|
|
|
|
//! Names for gui element types
|
|
const c8* const GUISkinTypeNames[] =
|
|
{
|
|
"windowsClassic",
|
|
"windowsMetallic",
|
|
"burning",
|
|
"unknown",
|
|
0,
|
|
};
|
|
|
|
|
|
//! Enumeration for skin colors
|
|
enum EGUI_DEFAULT_COLOR
|
|
{
|
|
//! Dark shadow for three-dimensional display elements.
|
|
EGDC_3D_DARK_SHADOW = 0,
|
|
//! Shadow color for three-dimensional display elements (for edges facing away from the light source).
|
|
EGDC_3D_SHADOW,
|
|
//! Face color for three-dimensional display elements and for dialog box backgrounds.
|
|
EGDC_3D_FACE,
|
|
//! Highlight color for three-dimensional display elements (for edges facing the light source.)
|
|
EGDC_3D_HIGH_LIGHT,
|
|
//! Light color for three-dimensional display elements (for edges facing the light source.)
|
|
EGDC_3D_LIGHT,
|
|
//! Active window border.
|
|
EGDC_ACTIVE_BORDER,
|
|
//! Active window title bar text.
|
|
EGDC_ACTIVE_CAPTION,
|
|
//! Background color of multiple document interface (MDI) applications.
|
|
EGDC_APP_WORKSPACE,
|
|
//! Text on a button
|
|
EGDC_BUTTON_TEXT,
|
|
//! Grayed (disabled) text.
|
|
EGDC_GRAY_TEXT,
|
|
//! Item(s) selected in a control.
|
|
EGDC_HIGH_LIGHT,
|
|
//! Text of item(s) selected in a control.
|
|
EGDC_HIGH_LIGHT_TEXT,
|
|
//! Inactive window border.
|
|
EGDC_INACTIVE_BORDER,
|
|
//! Inactive window caption.
|
|
EGDC_INACTIVE_CAPTION,
|
|
//! Tool tip color
|
|
EGDC_TOOLTIP,
|
|
//! Scrollbar gray area
|
|
EGDC_SCROLLBAR,
|
|
//! Window background
|
|
EGDC_WINDOW,
|
|
//! Window symbols like on close buttons, scroll bars and check boxes
|
|
EGDC_WINDOW_SYMBOL,
|
|
//! Icons in a list or tree
|
|
EGDC_ICON,
|
|
//! Selected icons in a list or tree
|
|
EGDC_ICON_HIGH_LIGHT,
|
|
//! this value is not used, it only specifies the amount of default colors
|
|
//! available.
|
|
EGDC_COUNT
|
|
};
|
|
|
|
//! Names for default skin colors
|
|
const c8* const GUISkinColorNames[] =
|
|
{
|
|
"3DDarkShadow",
|
|
"3DShadow",
|
|
"3DFace",
|
|
"3DHighlight",
|
|
"3DLight",
|
|
"ActiveBorder",
|
|
"ActiveCaption",
|
|
"AppWorkspace",
|
|
"ButtonText",
|
|
"GrayText",
|
|
"Highlight",
|
|
"HighlightText",
|
|
"InactiveBorder",
|
|
"InactiveCaption",
|
|
"ToolTip",
|
|
"ScrollBar",
|
|
"Window",
|
|
"WindowSymbol",
|
|
"Icon",
|
|
"IconHighlight",
|
|
0,
|
|
};
|
|
|
|
//! Enumeration for default sizes.
|
|
enum EGUI_DEFAULT_SIZE
|
|
{
|
|
//! default with / height of scrollbar
|
|
EGDS_SCROLLBAR_SIZE = 0,
|
|
//! height of menu
|
|
EGDS_MENU_HEIGHT,
|
|
//! width of a window button
|
|
EGDS_WINDOW_BUTTON_WIDTH,
|
|
//! width of a checkbox check
|
|
EGDS_CHECK_BOX_WIDTH,
|
|
//! width of a messagebox
|
|
EGDS_MESSAGE_BOX_WIDTH,
|
|
//! height of a messagebox
|
|
EGDS_MESSAGE_BOX_HEIGHT,
|
|
//! width of a default button
|
|
EGDS_BUTTON_WIDTH,
|
|
//! height of a default button
|
|
EGDS_BUTTON_HEIGHT,
|
|
//! distance for text from background
|
|
EGDS_TEXT_DISTANCE_X,
|
|
//! distance for text from background
|
|
EGDS_TEXT_DISTANCE_Y,
|
|
//! this value is not used, it only specifies the amount of default sizes
|
|
//! available.
|
|
EGDS_COUNT
|
|
};
|
|
|
|
|
|
//! Names for default skin sizes
|
|
const c8* const GUISkinSizeNames[] =
|
|
{
|
|
"ScrollBarSize",
|
|
"MenuHeight",
|
|
"WindowButtonWidth",
|
|
"CheckBoxWidth",
|
|
"MessageBoxWidth",
|
|
"MessageBoxHeight",
|
|
"ButtonWidth",
|
|
"ButtonHeight",
|
|
"TextDistanceX",
|
|
"TextDistanceY",
|
|
0,
|
|
};
|
|
|
|
|
|
enum EGUI_DEFAULT_TEXT
|
|
{
|
|
//! Text for the OK button on a message box
|
|
EGDT_MSG_BOX_OK = 0,
|
|
//! Text for the Cancel button on a message box
|
|
EGDT_MSG_BOX_CANCEL,
|
|
//! Text for the Yes button on a message box
|
|
EGDT_MSG_BOX_YES,
|
|
//! Text for the No button on a message box
|
|
EGDT_MSG_BOX_NO,
|
|
//! Tooltip text for window close button
|
|
EGDT_WINDOW_CLOSE,
|
|
//! Tooltip text for window maximize button
|
|
EGDT_WINDOW_MAXIMIZE,
|
|
//! Tooltip text for window minimize button
|
|
EGDT_WINDOW_MINIMIZE,
|
|
//! Tooltip text for window restore button
|
|
EGDT_WINDOW_RESTORE,
|
|
|
|
//! this value is not used, it only specifies the number of default texts
|
|
EGDT_COUNT
|
|
};
|
|
|
|
//! Names for default skin sizes
|
|
const c8* const GUISkinTextNames[] =
|
|
{
|
|
"MessageBoxOkay",
|
|
"MessageBoxCancel",
|
|
"MessageBoxYes",
|
|
"MessageBoxNo",
|
|
"WindowButtonClose",
|
|
"WindowButtonMaximize",
|
|
"WindowButtonMinimize",
|
|
"WindowButtonRestore",
|
|
0,
|
|
};
|
|
|
|
//! Customizable symbols for GUI
|
|
enum EGUI_DEFAULT_ICON
|
|
{
|
|
//! maximize window button
|
|
EGDI_WINDOW_MAXIMIZE = 0,
|
|
//! restore window button
|
|
EGDI_WINDOW_RESTORE,
|
|
//! close window button
|
|
EGDI_WINDOW_CLOSE,
|
|
//! minimize window button
|
|
EGDI_WINDOW_MINIMIZE,
|
|
//! scroll bar up button
|
|
EGDI_CURSOR_UP,
|
|
//! scroll bar down button
|
|
EGDI_CURSOR_DOWN,
|
|
//! scroll bar left button
|
|
EGDI_CURSOR_LEFT,
|
|
//! scroll bar right button
|
|
EGDI_CURSOR_RIGHT,
|
|
//! icon for menu children
|
|
EGDI_MENU_MORE,
|
|
//! tick for checkbox
|
|
EGDI_CHECK_BOX_CHECKED,
|
|
//! down arrow for dropdown menus
|
|
EGDI_DROP_DOWN,
|
|
//! smaller up arrow
|
|
EGDI_SMALL_CURSOR_UP,
|
|
//! smaller down arrow
|
|
EGDI_SMALL_CURSOR_DOWN,
|
|
//! selection dot in a radio button
|
|
EGDI_RADIO_BUTTON_CHECKED,
|
|
//! file icon for file selection
|
|
EGDI_FILE,
|
|
//! folder icon for file selection
|
|
EGDI_DIRECTORY,
|
|
|
|
//! value not used, it only specifies the number of icons
|
|
EGDI_COUNT
|
|
};
|
|
|
|
const c8* const GUISkinIconNames[] =
|
|
{
|
|
"windowMaximize",
|
|
"windowRestore",
|
|
"windowClose",
|
|
"windowMinimize",
|
|
"cursorUp",
|
|
"cursorDown",
|
|
"cursorLeft",
|
|
"cursorRight",
|
|
"menuMore",
|
|
"checkBoxChecked",
|
|
"dropDown",
|
|
"smallCursorUp",
|
|
"smallCursorDown",
|
|
"radioButtonChecked",
|
|
"file",
|
|
"directory",
|
|
0
|
|
};
|
|
|
|
//! A skin modifies the look of the GUI elements.
|
|
class IGUISkin : public virtual io::IAttributeExchangingObject
|
|
{
|
|
public:
|
|
|
|
//! destructor
|
|
~IGUISkin() {};
|
|
|
|
//! returns default color
|
|
virtual video::SColor getColor(EGUI_DEFAULT_COLOR color) = 0;
|
|
|
|
//! sets a default color
|
|
virtual void setColor(EGUI_DEFAULT_COLOR which, video::SColor newColor) = 0;
|
|
|
|
//! returns default color
|
|
virtual s32 getSize(EGUI_DEFAULT_SIZE size) = 0;
|
|
|
|
//! Returns a default text.
|
|
/** For example for Message box button captions:
|
|
"OK", "Cancel", "Yes", "No" and so on. */
|
|
virtual const wchar_t* getDefaultText(EGUI_DEFAULT_TEXT text) = 0;
|
|
|
|
//! Sets a default text.
|
|
/** For example for Message box button captions:
|
|
"OK", "Cancel", "Yes", "No" and so on. */
|
|
virtual void setDefaultText(EGUI_DEFAULT_TEXT which, const wchar_t* newText) = 0;
|
|
|
|
//! sets a default size
|
|
virtual void setSize(EGUI_DEFAULT_SIZE which, s32 size) = 0;
|
|
|
|
//! returns the default font
|
|
virtual IGUIFont* getFont() = 0;
|
|
|
|
//! sets a default font
|
|
virtual void setFont(IGUIFont* font) = 0;
|
|
|
|
//! returns the sprite bank
|
|
virtual IGUISpriteBank* getSpriteBank() = 0;
|
|
|
|
//! sets the sprite bank
|
|
virtual void setSpriteBank(IGUISpriteBank* bank) = 0;
|
|
|
|
//! Returns a default icon
|
|
/** Returns the sprite index within the sprite bank */
|
|
virtual u32 getIcon(EGUI_DEFAULT_ICON icon) = 0;
|
|
|
|
//! Sets a default icon
|
|
/** Sets the sprite index used for drawing icons like arrows,
|
|
close buttons and ticks in checkboxes
|
|
\param icon: Enum specifying which icon to change
|
|
\param index: The sprite index used to draw this icon */
|
|
virtual void setIcon(EGUI_DEFAULT_ICON icon, u32 index) = 0;
|
|
|
|
//! draws a standard 3d button pane
|
|
/** Used for drawing for example buttons in normal state.
|
|
It uses the colors EGDC_3D_DARK_SHADOW, EGDC_3D_HIGH_LIGHT, EGDC_3D_SHADOW and
|
|
EGDC_3D_FACE for this. See EGUI_DEFAULT_COLOR for details.
|
|
\param element: Pointer to the element which wishes to draw this. This parameter
|
|
is usually not used by IGUISkin, but can be used for example by more complex
|
|
implementations to find out how to draw the part exactly.
|
|
\param rect: Defining area where to draw.
|
|
\param clip: Clip area. */
|
|
virtual void draw3DButtonPaneStandard(IGUIElement* element,
|
|
const core::rect<s32>& rect,
|
|
const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! draws a pressed 3d button pane
|
|
/** Used for drawing for example buttons in pressed state.
|
|
It uses the colors EGDC_3D_DARK_SHADOW, EGDC_3D_HIGH_LIGHT, EGDC_3D_SHADOW and
|
|
EGDC_3D_FACE for this. See EGUI_DEFAULT_COLOR for details.
|
|
\param element: Pointer to the element which wishes to draw this. This parameter
|
|
is usually not used by IGUISkin, but can be used for example by more complex
|
|
implementations to find out how to draw the part exactly.
|
|
\param rect: Defining area where to draw.
|
|
\param clip: Clip area. */
|
|
virtual void draw3DButtonPanePressed(IGUIElement* element,
|
|
const core::rect<s32>& rect,
|
|
const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! draws a sunken 3d pane
|
|
/** Used for drawing the background of edit, combo or check boxes.
|
|
\param element: Pointer to the element which wishes to draw this. This parameter
|
|
is usually not used by IGUISkin, but can be used for example by more complex
|
|
implementations to find out how to draw the part exactly.
|
|
\param bgcolor: Background color.
|
|
\param flat: Specifies if the sunken pane should be flat or displayed as sunken
|
|
deep into the ground.
|
|
\param fillBackGround: Specifies if the background should be filled with the background
|
|
color or not be drawn at all.
|
|
\param rect: Defining area where to draw.
|
|
\param clip: Clip area. */
|
|
virtual void draw3DSunkenPane(IGUIElement* element,
|
|
video::SColor bgcolor, bool flat, bool fillBackGround,
|
|
const core::rect<s32>& rect,
|
|
const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! draws a window background
|
|
/** Used for drawing the background of dialogs and windows.
|
|
\param element: Pointer to the element which wishes to draw this. This parameter
|
|
is usually not used by IGUISkin, but can be used for example by more complex
|
|
implementations to find out how to draw the part exactly.
|
|
\param titleBarColor: Title color.
|
|
\param drawTitleBar: True to enable title drawing.
|
|
\param rect: Defining area where to draw.
|
|
\param clip: Clip area.
|
|
\return Returns rect where it would be good to draw title bar text. */
|
|
virtual core::rect<s32> draw3DWindowBackground(IGUIElement* element,
|
|
bool drawTitleBar, video::SColor titleBarColor,
|
|
const core::rect<s32>& rect,
|
|
const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! draws a standard 3d menu pane
|
|
/** Used for drawing for menus and context menus.
|
|
It uses the colors EGDC_3D_DARK_SHADOW, EGDC_3D_HIGH_LIGHT, EGDC_3D_SHADOW and
|
|
EGDC_3D_FACE for this. See EGUI_DEFAULT_COLOR for details.
|
|
\param element: Pointer to the element which wishes to draw this. This parameter
|
|
is usually not used by IGUISkin, but can be used for example by more complex
|
|
implementations to find out how to draw the part exactly.
|
|
\param rect: Defining area where to draw.
|
|
\param clip: Clip area. */
|
|
virtual void draw3DMenuPane(IGUIElement* element,
|
|
const core::rect<s32>& rect,
|
|
const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! draws a standard 3d tool bar
|
|
/** Used for drawing for toolbars and menus.
|
|
\param element: Pointer to the element which wishes to draw this. This parameter
|
|
is usually not used by IGUISkin, but can be used for example by more complex
|
|
implementations to find out how to draw the part exactly.
|
|
\param rect: Defining area where to draw.
|
|
\param clip: Clip area. */
|
|
virtual void draw3DToolBar(IGUIElement* element,
|
|
const core::rect<s32>& rect,
|
|
const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! draws a tab button
|
|
/** Used for drawing for tab buttons on top of tabs.
|
|
\param element: Pointer to the element which wishes to draw this. This parameter
|
|
is usually not used by IGUISkin, but can be used for example by more complex
|
|
implementations to find out how to draw the part exactly.
|
|
\param active: Specifies if the tab is currently active.
|
|
\param rect: Defining area where to draw.
|
|
\param clip: Clip area. */
|
|
virtual void draw3DTabButton(IGUIElement* element, bool active,
|
|
const core::rect<s32>& rect, const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! draws a tab control body
|
|
/** \param element: Pointer to the element which wishes to draw this. This parameter
|
|
is usually not used by IGUISkin, but can be used for example by more complex
|
|
implementations to find out how to draw the part exactly.
|
|
\param border: Specifies if the border should be drawn.
|
|
\param background: Specifies if the background should be drawn.
|
|
\param rect: Defining area where to draw.
|
|
\param clip: Clip area. */
|
|
virtual void draw3DTabBody(IGUIElement* element, bool border, bool background,
|
|
const core::rect<s32>& rect, const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! draws an icon, usually from the skin's sprite bank
|
|
/** \param element: Pointer to the element which wishes to draw this icon.
|
|
This parameter is usually not used by IGUISkin, but can be used for example
|
|
by more complex implementations to find out how to draw the part exactly.
|
|
\param icon: Specifies the icon to be drawn.
|
|
\param position: The position to draw the icon
|
|
\param starttime: The time at the start of the animation
|
|
\param currenttime: The present time, used to calculate the frame number
|
|
\param loop: Whether the animation should loop or not
|
|
\param clip: Clip area. */
|
|
virtual void drawIcon(IGUIElement* element, EGUI_DEFAULT_ICON icon,
|
|
const core::position2di position, u32 starttime=0, u32 currenttime=0,
|
|
bool loop=false, const core::rect<s32>* clip=0) = 0;
|
|
|
|
//! get the type of this skin
|
|
virtual EGUI_SKIN_TYPE getType() const { return EGST_UNKNOWN; };
|
|
|
|
};
|
|
|
|
|
|
} // end namespace gui
|
|
} // end namespace irr
|
|
|
|
#endif
|
|
|