mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-17 23:44:22 +00:00
5510640dbc
The width of each tab is now computed from its title, independently of the other tabs. This increases the number of tabs that fit on the screen. This rewrite also fixes a bug where if the window size increased while _firstVisibleTab > 0, some tabs would become inaccessible when the scroll buttons were hidden. The layout key Globals.TabWidget.Tab.Width is now treated as minimal tab width. This is set so that the tabs fit reasonably well in lowres layouts. At the same time, this reduces the lowres scroll buttons heights to fit. This patch makes the Nintento DS hacks in TabWidget obsolete. (Hopefully! I'm not able to test.)
765 lines
28 KiB
C++
765 lines
28 KiB
C++
/* ScummVM - Graphic Adventure Engine
|
|
*
|
|
* ScummVM is the legal property of its developers, whose names
|
|
* are too numerous to list here. Please refer to the COPYRIGHT
|
|
* file distributed with this source distribution.
|
|
*
|
|
* 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 2
|
|
* 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*
|
|
*/
|
|
|
|
#ifndef GUI_THEME_ENGINE_H
|
|
#define GUI_THEME_ENGINE_H
|
|
|
|
#include "common/scummsys.h"
|
|
#include "common/fs.h"
|
|
#include "common/hash-str.h"
|
|
#include "common/hashmap.h"
|
|
#include "common/list.h"
|
|
#include "common/str.h"
|
|
#include "common/rect.h"
|
|
|
|
#include "graphics/surface.h"
|
|
#include "graphics/transparent_surface.h"
|
|
#include "graphics/font.h"
|
|
#include "graphics/pixelformat.h"
|
|
|
|
|
|
#define SCUMMVM_THEME_VERSION_STR "SCUMMVM_STX0.8.23"
|
|
|
|
class OSystem;
|
|
|
|
namespace Graphics {
|
|
struct DrawStep;
|
|
class VectorRenderer;
|
|
}
|
|
|
|
namespace GUI {
|
|
|
|
struct WidgetDrawData;
|
|
struct TextDrawData;
|
|
struct TextColorData;
|
|
class Dialog;
|
|
class GuiObject;
|
|
class ThemeEval;
|
|
class ThemeItem;
|
|
class ThemeParser;
|
|
|
|
/**
|
|
* DrawData sets enumeration.
|
|
* Each DD set corresponds to the actual looks
|
|
* of a widget in a given state.
|
|
*/
|
|
enum DrawData {
|
|
kDDMainDialogBackground,
|
|
kDDSpecialColorBackground,
|
|
kDDPlainColorBackground,
|
|
kDDTooltipBackground,
|
|
kDDDefaultBackground,
|
|
kDDTextSelectionBackground,
|
|
kDDTextSelectionFocusBackground,
|
|
|
|
kDDWidgetBackgroundDefault,
|
|
kDDWidgetBackgroundSmall,
|
|
kDDWidgetBackgroundEditText,
|
|
kDDWidgetBackgroundSlider,
|
|
|
|
kDDButtonIdle,
|
|
kDDButtonHover,
|
|
kDDButtonDisabled,
|
|
kDDButtonPressed,
|
|
|
|
kDDSliderFull,
|
|
kDDSliderHover,
|
|
kDDSliderDisabled,
|
|
|
|
kDDCheckboxDefault,
|
|
kDDCheckboxDisabled,
|
|
kDDCheckboxSelected,
|
|
|
|
kDDRadiobuttonDefault,
|
|
kDDRadiobuttonDisabled,
|
|
kDDRadiobuttonSelected,
|
|
|
|
kDDTabActive,
|
|
kDDTabInactive,
|
|
kDDTabBackground,
|
|
|
|
kDDScrollbarBase,
|
|
kDDScrollbarButtonIdle,
|
|
kDDScrollbarButtonHover,
|
|
kDDScrollbarHandleIdle,
|
|
kDDScrollbarHandleHover,
|
|
|
|
kDDPopUpIdle,
|
|
kDDPopUpHover,
|
|
kDDPopUpDisabled,
|
|
|
|
kDDCaret,
|
|
kDDSeparator,
|
|
kDrawDataMAX,
|
|
kDDNone = -1
|
|
};
|
|
|
|
// FIXME: TextData is really a bad name, not conveying what this enum is about.
|
|
enum TextData {
|
|
kTextDataNone = -1,
|
|
kTextDataDefault = 0,
|
|
kTextDataButton,
|
|
kTextDataNormalFont,
|
|
kTextDataTooltip,
|
|
kTextDataMAX
|
|
};
|
|
|
|
enum TextColor {
|
|
kTextColorNormal = 0,
|
|
kTextColorNormalInverted,
|
|
kTextColorNormalHover,
|
|
kTextColorNormalDisabled,
|
|
kTextColorAlternative,
|
|
kTextColorAlternativeInverted,
|
|
kTextColorAlternativeHover,
|
|
kTextColorAlternativeDisabled,
|
|
kTextColorButton,
|
|
kTextColorButtonHover,
|
|
kTextColorButtonDisabled,
|
|
kTextColorMAX
|
|
};
|
|
|
|
class ThemeEngine {
|
|
protected:
|
|
typedef Common::HashMap<Common::String, Graphics::Surface *> ImagesMap;
|
|
typedef Common::HashMap<Common::String, Graphics::TransparentSurface *> AImagesMap;
|
|
|
|
friend class GUI::Dialog;
|
|
friend class GUI::GuiObject;
|
|
|
|
public:
|
|
/// Vertical alignment of the text.
|
|
enum TextAlignVertical {
|
|
kTextAlignVInvalid,
|
|
kTextAlignVBottom,
|
|
kTextAlignVCenter,
|
|
kTextAlignVTop
|
|
};
|
|
|
|
/// Widget background type
|
|
enum WidgetBackground {
|
|
kWidgetBackgroundNo, ///< No background at all
|
|
kWidgetBackgroundPlain, ///< Simple background, this may not include borders
|
|
kWidgetBackgroundBorder, ///< Same as kWidgetBackgroundPlain just with a border
|
|
kWidgetBackgroundBorderSmall, ///< Same as kWidgetBackgroundPlain just with a small border
|
|
kWidgetBackgroundEditText, ///< Background used for edit text fields
|
|
kWidgetBackgroundSlider ///< Background used for sliders
|
|
};
|
|
|
|
/// Dialog background type
|
|
enum DialogBackground {
|
|
kDialogBackgroundMain,
|
|
kDialogBackgroundSpecial,
|
|
kDialogBackgroundPlain,
|
|
kDialogBackgroundTooltip,
|
|
kDialogBackgroundDefault,
|
|
kDialogBackgroundNone
|
|
};
|
|
|
|
/// State of the widget to be drawn
|
|
enum State {
|
|
kStateDisabled, ///< Indicates that the widget is disabled, that does NOT include that it is invisible
|
|
kStateEnabled, ///< Indicates that the widget is enabled
|
|
kStateHighlight, ///< Indicates that the widget is highlighted by the user
|
|
kStatePressed ///< Indicates that the widget is pressed, currently works for buttons
|
|
};
|
|
|
|
typedef State WidgetStateInfo;
|
|
|
|
/// Text inversion state of the text to be draw
|
|
enum TextInversionState {
|
|
kTextInversionNone, ///< Indicates that the text should not be drawn inverted
|
|
kTextInversion, ///< Indicates that the text should be drawn inverted, but not focused
|
|
kTextInversionFocus ///< Indicates that the text should be drawn inverted, and focused
|
|
};
|
|
|
|
enum ScrollbarState {
|
|
kScrollbarStateNo,
|
|
kScrollbarStateUp,
|
|
kScrollbarStateDown,
|
|
kScrollbarStateSlider,
|
|
kScrollbarStateSinglePage
|
|
};
|
|
|
|
/// Font style selector
|
|
enum FontStyle {
|
|
kFontStyleBold = 0, ///< A bold font. This is also the default font.
|
|
kFontStyleNormal = 1, ///< A normal font.
|
|
kFontStyleItalic = 2, ///< Italic styled font.
|
|
kFontStyleFixedNormal = 3, ///< Fixed size font.
|
|
kFontStyleFixedBold = 4, ///< Fixed size bold font.
|
|
kFontStyleFixedItalic = 5, ///< Fixed size italic font.
|
|
kFontStyleTooltip = 6, ///< Tiny console font
|
|
kFontStyleMax
|
|
};
|
|
|
|
/// Font color selector
|
|
enum FontColor {
|
|
kFontColorNormal = 0, ///< The default color of the theme
|
|
kFontColorAlternate = 1, ///< Alternative font color
|
|
kFontColorMax
|
|
};
|
|
|
|
/// Function used to process areas other than the current dialog
|
|
enum ShadingStyle {
|
|
kShadingNone, ///< No special post processing
|
|
kShadingDim, ///< Dimming unused areas
|
|
kShadingLuminance ///< Converting colors to luminance for unused areas
|
|
};
|
|
|
|
/// AlphaBitmap scale mode selector
|
|
enum AutoScaleMode {
|
|
kAutoScaleNone = 0, ///< Use image dimensions
|
|
kAutoScaleStretch = 1, ///< Stretch image to full widget size
|
|
kAutoScaleFit = 2, ///< Scale image to widget size but keep aspect ratio
|
|
kAutoScaleNinePatch = 3 ///< 9-patch image
|
|
};
|
|
|
|
// Special image ids for images used in the GUI
|
|
static const char *const kImageLogo; ///< ScummVM logo used in the launcher
|
|
static const char *const kImageLogoSmall; ///< ScummVM logo used in the GMM
|
|
static const char *const kImageSearch; ///< Search tool image used in the launcher
|
|
static const char *const kImageEraser; ///< Clear input image used in the launcher
|
|
static const char *const kImageDelButton; ///< Delete characters in the predictive dialog
|
|
static const char *const kImageList; ///< List image used in save/load chooser selection
|
|
static const char *const kImageGrid; ///< Grid image used in save/load chooser selection
|
|
static const char *const kImageStopButton; ///< Stop recording button in recorder onscreen dialog
|
|
static const char *const kImageEditButton; ///< Edit recording metadata in recorder onscreen dialog
|
|
static const char *const kImageSwitchModeButton; ///< Switch mode button in recorder onscreen dialog
|
|
static const char *const kImageFastReplayButton; ///< Fast playback mode button in recorder onscreen dialog
|
|
static const char *const kImageStopSmallButton; ///< Stop recording button in recorder onscreen dialog (for 320xY)
|
|
static const char *const kImageEditSmallButton; ///< Edit recording metadata in recorder onscreen dialog (for 320xY)
|
|
static const char *const kImageSwitchModeSmallButton; ///< Switch mode button in recorder onscreen dialog (for 320xY)
|
|
static const char *const kImageFastReplaySmallButton; ///< Fast playback mode button in recorder onscreen dialog (for 320xY)
|
|
static const char *const kImageDropboxLogo; ///< Dropbox logo used in the StorageWizardDialog
|
|
static const char *const kImageOneDriveLogo; ///< OneDrive logo used in the StorageWizardDialog
|
|
static const char *const kImageGoogleDriveLogo; ///< Google Drive logo used in the StorageWizardDialog
|
|
static const char *const kImageBoxLogo; ///< Box logo used in the StorageWizardDialog
|
|
|
|
/**
|
|
* Graphics mode enumeration.
|
|
* Each item represents a set of BPP and Renderer modes for a given
|
|
* surface.
|
|
*/
|
|
enum GraphicsMode {
|
|
kGfxDisabled = 0, ///< No GFX
|
|
kGfxStandard, ///< Standard (aliased) renderer.
|
|
kGfxAntialias ///< Optimized AA renderer.
|
|
};
|
|
|
|
/** Constant value to expand dirty rectangles, to make sure they are fully copied */
|
|
static const int kDirtyRectangleThreshold = 1;
|
|
|
|
struct Renderer {
|
|
const char *name;
|
|
const char *shortname;
|
|
const char *cfg;
|
|
GraphicsMode mode;
|
|
};
|
|
|
|
static const Renderer _rendererModes[];
|
|
static const uint _rendererModesSize;
|
|
|
|
static const GraphicsMode _defaultRendererMode;
|
|
|
|
static GraphicsMode findMode(const Common::String &cfg);
|
|
static const char *findModeConfigName(GraphicsMode mode);
|
|
|
|
/** Default constructor */
|
|
ThemeEngine(Common::String id, GraphicsMode mode);
|
|
|
|
/** Default destructor */
|
|
~ThemeEngine();
|
|
|
|
bool init();
|
|
void clearAll();
|
|
|
|
void refresh();
|
|
void enable();
|
|
|
|
void showCursor();
|
|
void hideCursor();
|
|
|
|
void disable();
|
|
|
|
|
|
/**
|
|
* Query the set up pixel format.
|
|
*/
|
|
const Graphics::PixelFormat getPixelFormat() const { return _overlayFormat; }
|
|
|
|
/**
|
|
* Implementation of the GUI::Theme API. Called when a
|
|
* new dialog is opened. Note that the boolean parameter
|
|
* meaning has been changed.
|
|
*
|
|
* @param enableBuffering If set to true, buffering is enabled for
|
|
* drawing this dialog, and will continue enabled
|
|
* until disabled.
|
|
*/
|
|
void openDialog(bool enableBuffering, ShadingStyle shading = kShadingNone);
|
|
|
|
/**
|
|
* The updateScreen() method is called every frame.
|
|
* It processes all the drawing queues and then copies dirty rects
|
|
* in the current Screen surface to the overlay.
|
|
*/
|
|
void updateScreen(bool render = true);
|
|
|
|
|
|
/** @name FONT MANAGEMENT METHODS */
|
|
//@{
|
|
|
|
TextData fontStyleToData(FontStyle font) const {
|
|
if (font == kFontStyleNormal)
|
|
return kTextDataNormalFont;
|
|
if (font == kFontStyleTooltip)
|
|
return kTextDataTooltip;
|
|
return kTextDataDefault;
|
|
}
|
|
|
|
const Graphics::Font *getFont(FontStyle font = kFontStyleBold) const;
|
|
|
|
int getFontHeight(FontStyle font = kFontStyleBold) const;
|
|
|
|
int getStringWidth(const Common::String &str, FontStyle font = kFontStyleBold) const;
|
|
|
|
int getCharWidth(byte c, FontStyle font = kFontStyleBold) const;
|
|
|
|
int getKerningOffset(byte left, byte right, FontStyle font = kFontStyleBold) const;
|
|
|
|
//@}
|
|
|
|
|
|
/** @name WIDGET DRAWING METHODS */
|
|
//@{
|
|
|
|
void drawWidgetBackground(const Common::Rect &r, uint16 hints,
|
|
WidgetBackground background = kWidgetBackgroundPlain, WidgetStateInfo state = kStateEnabled);
|
|
void drawWidgetBackgroundClip(const Common::Rect &r, const Common::Rect &clippingArea, uint16 hints,
|
|
WidgetBackground background = kWidgetBackgroundPlain, WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawButton(const Common::Rect &r, const Common::String &str,
|
|
WidgetStateInfo state = kStateEnabled, uint16 hints = 0);
|
|
void drawButtonClip(const Common::Rect &r, const Common::Rect &clippingRect, const Common::String &str,
|
|
WidgetStateInfo state = kStateEnabled, uint16 hints = 0);
|
|
|
|
void drawSurface(const Common::Rect &r, const Graphics::Surface &surface,
|
|
WidgetStateInfo state = kStateEnabled, int alpha = 255, bool themeTrans = false);
|
|
void drawSurfaceClip(const Common::Rect &r, const Common::Rect &clippingRect, const Graphics::Surface &surface,
|
|
WidgetStateInfo state = kStateEnabled, int alpha = 255, bool themeTrans = false);
|
|
|
|
void drawASurface(const Common::Rect &r, Graphics::TransparentSurface &surface, AutoScaleMode autoscale, int alpha);
|
|
|
|
void drawSlider(const Common::Rect &r, int width,
|
|
WidgetStateInfo state = kStateEnabled);
|
|
void drawSliderClip(const Common::Rect &r, const Common::Rect &clippingRect, int width,
|
|
WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawCheckbox(const Common::Rect &r, const Common::String &str,
|
|
bool checked, WidgetStateInfo state = kStateEnabled);
|
|
void drawCheckboxClip(const Common::Rect &r, const Common::Rect &clippingRect, const Common::String &str,
|
|
bool checked, WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawRadiobutton(const Common::Rect &r, const Common::String &str,
|
|
bool checked, WidgetStateInfo state = kStateEnabled);
|
|
void drawRadiobuttonClip(const Common::Rect &r, const Common::Rect &clippingRect, const Common::String &str,
|
|
bool checked, WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawTab(const Common::Rect &r, int tabHeight, int tabWidth,
|
|
const Common::Array<Common::String> &tabs, int active, uint16 hints,
|
|
int titleVPad, WidgetStateInfo state = kStateEnabled);
|
|
void drawTabClip(const Common::Rect &r, const Common::Rect &clippingRect, int tabHeight, const Common::Array<int> &tabWidths,
|
|
const Common::Array<Common::String> &tabs, int active, uint16 hints,
|
|
int titleVPad, WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawScrollbar(const Common::Rect &r, int sliderY, int sliderHeight,
|
|
ScrollbarState, WidgetStateInfo state = kStateEnabled);
|
|
void drawScrollbarClip(const Common::Rect &r, const Common::Rect &clippingRect, int sliderY, int sliderHeight,
|
|
ScrollbarState scrollState, WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawPopUpWidget(const Common::Rect &r, const Common::String &sel,
|
|
int deltax, WidgetStateInfo state = kStateEnabled, Graphics::TextAlign align = Graphics::kTextAlignLeft);
|
|
void drawPopUpWidgetClip(const Common::Rect &r, const Common::Rect &clippingArea, const Common::String &sel,
|
|
int deltax, WidgetStateInfo state = kStateEnabled, Graphics::TextAlign align = Graphics::kTextAlignLeft);
|
|
|
|
void drawCaret(const Common::Rect &r, bool erase,
|
|
WidgetStateInfo state = kStateEnabled);
|
|
void drawCaretClip(const Common::Rect &r, const Common::Rect &clip, bool erase,
|
|
WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawLineSeparator(const Common::Rect &r, WidgetStateInfo state = kStateEnabled);
|
|
void drawLineSeparatorClip(const Common::Rect &r, const Common::Rect &clippingArea, WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawDialogBackground(const Common::Rect &r, DialogBackground type, WidgetStateInfo state = kStateEnabled);
|
|
void drawDialogBackgroundClip(const Common::Rect &r, const Common::Rect &clip, DialogBackground type, WidgetStateInfo state = kStateEnabled);
|
|
|
|
void drawText(const Common::Rect &r, const Common::String &str, WidgetStateInfo state = kStateEnabled, Graphics::TextAlign align = Graphics::kTextAlignCenter, TextInversionState inverted = kTextInversionNone, int deltax = 0, bool useEllipsis = true, FontStyle font = kFontStyleBold, FontColor color = kFontColorNormal, bool restore = true, const Common::Rect &drawableTextArea = Common::Rect(0, 0, 0, 0));
|
|
void drawTextClip(const Common::Rect &r, const Common::Rect &clippingArea, const Common::String &str, WidgetStateInfo state = kStateEnabled, Graphics::TextAlign align = Graphics::kTextAlignCenter, TextInversionState inverted = kTextInversionNone, int deltax = 0, bool useEllipsis = true, FontStyle font = kFontStyleBold, FontColor color = kFontColorNormal, bool restore = true, const Common::Rect &drawableTextArea = Common::Rect(0, 0, 0, 0));
|
|
|
|
void drawChar(const Common::Rect &r, byte ch, const Graphics::Font *font, WidgetStateInfo state = kStateEnabled, FontColor color = kFontColorNormal);
|
|
void drawCharClip(const Common::Rect &r, const Common::Rect &clippingArea, byte ch, const Graphics::Font *font, WidgetStateInfo state = kStateEnabled, FontColor color = kFontColorNormal);
|
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
* Actual implementation of a dirty rect handling.
|
|
* Dirty rectangles are queued on a list and are later used for the
|
|
* actual drawing.
|
|
*
|
|
* @param r Area of the dirty rect.
|
|
*/
|
|
void addDirtyRect(Common::Rect r);
|
|
|
|
|
|
/**
|
|
* Returns the DrawData enumeration value that represents the given string
|
|
* in the DrawDataDefaults enumeration.
|
|
* It's slow, but called sparsely.
|
|
*
|
|
* @returns The drawdata enum value, or -1 if not found.
|
|
* @param name The representing name, as found on Theme Description XML files.
|
|
* @see kDrawDataDefaults[]
|
|
*/
|
|
DrawData parseDrawDataId(const Common::String &name) const;
|
|
|
|
TextData getTextData(DrawData ddId) const;
|
|
TextColor getTextColor(DrawData ddId) const;
|
|
|
|
|
|
/**
|
|
* Interface for ThemeParser class: Parsed DrawSteps are added via this function.
|
|
* There is no return type because DrawSteps can always be added, unless something
|
|
* goes horribly wrong.
|
|
* The specified step will be added to the Steps list of the given DrawData id.
|
|
*
|
|
* @param drawDataId The representing DrawData name, as found on Theme Description XML files.
|
|
* @param step The actual DrawStep struct to be added.
|
|
*/
|
|
void addDrawStep(const Common::String &drawDataId, const Graphics::DrawStep &step);
|
|
|
|
/**
|
|
* Interface for the ThemeParser class: Parsed DrawData sets are added via this function.
|
|
* The goal of the function is to initialize each DrawData set before their DrawSteps can
|
|
* be added, hence this must be called for each DD set before addDrawStep() can be called
|
|
* for that given set.
|
|
*
|
|
* @param data The representing DrawData name, as found on Theme Description XML files.
|
|
* @param cached Whether this DD set will be cached beforehand.
|
|
*/
|
|
bool addDrawData(const Common::String &data, bool cached);
|
|
|
|
|
|
/**
|
|
* Interface for the ThemeParser class: Loads a font to use on the GUI from the given
|
|
* filename.
|
|
*
|
|
* @param textId Identifier name for the font.
|
|
* @param file Filename of the non-scalable font version.
|
|
* @param scalableFile Filename of the scalable version. (Optional)
|
|
* @param pointsize Point size for the scalable font. (Optional)
|
|
*/
|
|
bool addFont(TextData textId, const Common::String &file, const Common::String &scalableFile, const int pointsize);
|
|
|
|
/**
|
|
* Interface for the ThemeParser class: adds a text color value.
|
|
*
|
|
* @param colorId Identifier for the color type.
|
|
* @param r, g, b Color of the font.
|
|
*/
|
|
bool addTextColor(TextColor colorId, int r, int g, int b);
|
|
|
|
|
|
/**
|
|
* Interface for the ThemeParser class: Loads a bitmap file to use on the GUI.
|
|
* The filename is also used as its identifier.
|
|
*
|
|
* @param filename Name of the bitmap file.
|
|
*/
|
|
bool addBitmap(const Common::String &filename);
|
|
|
|
/**
|
|
* Interface for the ThemeParser class: Loads a bitmap with transparency file to use on the GUI.
|
|
* The filename is also used as its identifier.
|
|
*
|
|
* @param filename Name of the bitmap file.
|
|
*/
|
|
bool addAlphaBitmap(const Common::String &filename);
|
|
|
|
/**
|
|
* Adds a new TextStep from the ThemeParser. This will be deprecated/removed once the
|
|
* new Font API is in place. FIXME: Is that so ???
|
|
*/
|
|
bool addTextData(const Common::String &drawDataId, TextData textId, TextColor id, Graphics::TextAlign alignH, TextAlignVertical alignV);
|
|
|
|
protected:
|
|
/**
|
|
* Returns if the Theme is ready to draw stuff on screen.
|
|
* Must be called instead of just checking _initOk, because
|
|
* this checks if the renderer is initialized AND if the theme
|
|
* is loaded.
|
|
*/
|
|
bool ready() const {
|
|
return _initOk && _themeOk;
|
|
}
|
|
|
|
/** Load the them from the file with the specified name. */
|
|
void loadTheme(const Common::String &themeid);
|
|
|
|
/**
|
|
* Changes the active graphics mode of the GUI; may be used to either
|
|
* initialize the GUI or to change the mode while the GUI is already running.
|
|
*/
|
|
void setGraphicsMode(GraphicsMode mode);
|
|
|
|
public:
|
|
/**
|
|
* Finishes buffering: widgets from then on will be drawn straight on the screen
|
|
* without drawing queues.
|
|
*/
|
|
inline void finishBuffering() { _buffering = false; }
|
|
inline void startBuffering() { _buffering = true; }
|
|
|
|
inline ThemeEval *getEvaluator() { return _themeEval; }
|
|
inline Graphics::VectorRenderer *renderer() { return _vectorRenderer; }
|
|
|
|
inline bool supportsImages() const { return true; }
|
|
inline bool ownCursor() const { return _useCursor; }
|
|
|
|
Graphics::Surface *getBitmap(const Common::String &name) {
|
|
return _bitmaps.contains(name) ? _bitmaps[name] : 0;
|
|
}
|
|
|
|
Graphics::TransparentSurface *getAlphaBitmap(const Common::String &name) {
|
|
return _abitmaps.contains(name) ? _abitmaps[name] : 0;
|
|
}
|
|
|
|
const Graphics::Surface *getImageSurface(const Common::String &name) const {
|
|
return _bitmaps.contains(name) ? _bitmaps[name] : 0;
|
|
}
|
|
|
|
const Graphics::TransparentSurface *getAImageSurface(const Common::String &name) const {
|
|
return _abitmaps.contains(name) ? _abitmaps[name] : 0;
|
|
}
|
|
|
|
/**
|
|
* Interface for the Theme Parser: Creates a new cursor by loading the given
|
|
* bitmap and sets it as the active cursor.
|
|
*
|
|
* @param filename File name of the bitmap to load.
|
|
* @param hotspotX X Coordinate of the bitmap which does the cursor click.
|
|
* @param hotspotY Y Coordinate of the bitmap which does the cursor click.
|
|
*/
|
|
bool createCursor(const Common::String &filename, int hotspotX, int hotspotY);
|
|
|
|
/**
|
|
* Wrapper for restoring data from the Back Buffer to the screen.
|
|
* The actual processing is done in the VectorRenderer.
|
|
*
|
|
* @param r Area to restore.
|
|
*/
|
|
void restoreBackground(Common::Rect r);
|
|
|
|
const Common::String &getThemeName() const { return _themeName; }
|
|
const Common::String &getThemeId() const { return _themeId; }
|
|
int getGraphicsMode() const { return _graphicsMode; }
|
|
|
|
protected:
|
|
/**
|
|
* Initializes the drawing screen surfaces, _screen and _backBuffer.
|
|
* If the surfaces already exist, they are cleared and re-initialized.
|
|
*
|
|
* @param backBuffer Sets whether the _backBuffer surface should be initialized.
|
|
* @template PixelType C type which specifies the size of each pixel.
|
|
* Defaults to uint16 (2 BPP for the surfaces)
|
|
*/
|
|
template<typename PixelType> void screenInit(bool backBuffer = true);
|
|
|
|
/**
|
|
* Loads the given theme into the ThemeEngine.
|
|
*
|
|
* @param themeId Theme identifier.
|
|
* @returns true if the theme was successfully loaded.
|
|
*/
|
|
bool loadThemeXML(const Common::String &themeId);
|
|
|
|
/**
|
|
* Loads the default theme file (the embedded XML file found
|
|
* in ThemeDefaultXML.cpp).
|
|
* Called only when no other themes are available.
|
|
*/
|
|
bool loadDefaultXML();
|
|
|
|
/**
|
|
* Unloads the currently loaded theme so another one can
|
|
* be loaded.
|
|
*/
|
|
void unloadTheme();
|
|
|
|
const Graphics::Font *loadScalableFont(const Common::String &filename, const Common::String &charset, const int pointsize, Common::String &name);
|
|
const Graphics::Font *loadFont(const Common::String &filename, Common::String &name);
|
|
Common::String genCacheFilename(const Common::String &filename) const;
|
|
const Graphics::Font *loadFont(const Common::String &filename, const Common::String &scalableFilename, const Common::String &charset, const int pointsize, const bool makeLocalizedFont);
|
|
|
|
/**
|
|
* Actual Dirty Screen handling function.
|
|
* Handles all the dirty squares in the list, merges and optimizes
|
|
* them when possible and draws them to the screen.
|
|
* Called from updateScreen()
|
|
*/
|
|
void renderDirtyScreen();
|
|
|
|
/**
|
|
* Generates a DrawQueue item and enqueues it so it's drawn to the screen
|
|
* when the drawing queue is processed.
|
|
*
|
|
* If Buffering is enabled, the DrawQueue item will be automatically placed
|
|
* on its corresponding queue.
|
|
* If Buffering is disabled, the DrawQueue item will be processed immediately
|
|
* and drawn to the screen.
|
|
*
|
|
* This function is called from all the Widget Drawing methods.
|
|
*/
|
|
void queueDD(DrawData type, const Common::Rect &r, uint32 dynamic = 0, bool restore = false);
|
|
void queueDDClip(DrawData type, const Common::Rect &r, const Common::Rect &clippingRect, uint32 dynamic = 0, bool restore = false);
|
|
void queueDDText(TextData type, TextColor color, const Common::Rect &r, const Common::String &text, bool restoreBg,
|
|
bool elipsis, Graphics::TextAlign alignH = Graphics::kTextAlignLeft, TextAlignVertical alignV = kTextAlignVTop, int deltax = 0, const Common::Rect &drawableTextArea = Common::Rect(0, 0, 0, 0));
|
|
void queueDDTextClip(TextData type, TextColor color, const Common::Rect &r, const Common::Rect &clippingRect, const Common::String &text, bool restoreBg,
|
|
bool elipsis, Graphics::TextAlign alignH = Graphics::kTextAlignLeft, TextAlignVertical alignV = kTextAlignVTop, int deltax = 0, const Common::Rect &drawableTextArea = Common::Rect(0, 0, 0, 0));
|
|
void queueBitmap(const Graphics::Surface *bitmap, const Common::Rect &r, bool alpha);
|
|
void queueBitmapClip(const Graphics::Surface *bitmap, const Common::Rect &clippingRect, const Common::Rect &r, bool alpha);
|
|
void queueABitmap(Graphics::TransparentSurface *bitmap, const Common::Rect &r, AutoScaleMode autoscale, int alpha);
|
|
|
|
/**
|
|
* DEBUG: Draws a white square and writes some text next to it.
|
|
*/
|
|
void debugWidgetPosition(const char *name, const Common::Rect &r);
|
|
|
|
public:
|
|
struct ThemeDescriptor {
|
|
Common::String name;
|
|
Common::String id;
|
|
Common::String filename;
|
|
};
|
|
|
|
/**
|
|
* Lists all theme files useable.
|
|
*/
|
|
static void listUsableThemes(Common::List<ThemeDescriptor> &list);
|
|
private:
|
|
static bool themeConfigUsable(const Common::FSNode &node, Common::String &themeName);
|
|
static bool themeConfigUsable(const Common::ArchiveMember &member, Common::String &themeName);
|
|
static bool themeConfigParseHeader(Common::String header, Common::String &themeName);
|
|
|
|
static Common::String getThemeFile(const Common::String &id);
|
|
static Common::String getThemeId(const Common::String &filename);
|
|
static void listUsableThemes(const Common::FSNode &node, Common::List<ThemeDescriptor> &list, int depth = -1);
|
|
static void listUsableThemes(Common::Archive &archive, Common::List<ThemeDescriptor> &list);
|
|
|
|
protected:
|
|
OSystem *_system; /** Global system object. */
|
|
|
|
/** Vector Renderer object, does the actual drawing on screen */
|
|
Graphics::VectorRenderer *_vectorRenderer;
|
|
|
|
/** XML Parser, does the Theme parsing instead of the default parser */
|
|
GUI::ThemeParser *_parser;
|
|
|
|
/** Theme getEvaluator (changed from GUI::Eval to add functionality) */
|
|
GUI::ThemeEval *_themeEval;
|
|
|
|
/** Main screen surface. This is blitted straight into the overlay. */
|
|
Graphics::TransparentSurface _screen;
|
|
|
|
/** Backbuffer surface. Stores previous states of the screen to blit back */
|
|
Graphics::TransparentSurface _backBuffer;
|
|
|
|
/** Sets whether the current drawing is being buffered (stored for later
|
|
processing) or drawn directly to the screen. */
|
|
bool _buffering;
|
|
|
|
/** Bytes per pixel of the Active Drawing Surface (i.e. the screen) */
|
|
int _bytesPerPixel;
|
|
|
|
/** Current graphics mode */
|
|
GraphicsMode _graphicsMode;
|
|
|
|
/** Font info. */
|
|
Common::String _fontName;
|
|
const Graphics::Font *_font;
|
|
|
|
/**
|
|
* Array of all the DrawData elements than can be drawn to the screen.
|
|
* Must be full so the renderer can work.
|
|
*/
|
|
WidgetDrawData *_widgets[kDrawDataMAX];
|
|
|
|
/** Array of all the text fonts that can be drawn. */
|
|
TextDrawData *_texts[kTextDataMAX];
|
|
|
|
/** Array of all font colors available. */
|
|
TextColorData *_textColors[kTextColorMAX];
|
|
|
|
ImagesMap _bitmaps;
|
|
AImagesMap _abitmaps;
|
|
Graphics::PixelFormat _overlayFormat;
|
|
#ifdef USE_RGB_COLOR
|
|
Graphics::PixelFormat _cursorFormat;
|
|
#endif
|
|
|
|
/** List of all the dirty screens that must be blitted to the overlay. */
|
|
Common::List<Common::Rect> _dirtyScreen;
|
|
|
|
/** Queue with all the drawing that must be done to the Back Buffer */
|
|
Common::List<ThemeItem *> _bufferQueue;
|
|
|
|
/** Queue with all the drawing that must be done to the screen */
|
|
Common::List<ThemeItem *> _screenQueue;
|
|
|
|
bool _initOk; ///< Class and renderer properly initialized
|
|
bool _themeOk; ///< Theme data successfully loaded.
|
|
bool _enabled; ///< Whether the Theme is currently shown on the overlay
|
|
|
|
Common::String _themeName; ///< Name of the currently loaded theme
|
|
Common::String _themeId;
|
|
Common::String _themeFile;
|
|
Common::Archive *_themeArchive;
|
|
Common::SearchSet _themeFiles;
|
|
|
|
bool _useCursor;
|
|
int _cursorHotspotX, _cursorHotspotY;
|
|
enum {
|
|
MAX_CURS_COLORS = 255
|
|
};
|
|
byte *_cursor;
|
|
bool _needPaletteUpdates;
|
|
uint _cursorWidth, _cursorHeight;
|
|
byte _cursorPal[3 * MAX_CURS_COLORS];
|
|
byte _cursorPalSize;
|
|
};
|
|
|
|
} // End of namespace GUI.
|
|
|
|
#endif
|