added system colours and fonts support to XRC (based on patch #1038207)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@30524 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
66266922ca
commit
1df61962e8
@ -229,9 +229,10 @@ All:
|
|||||||
- A new data type specific to wxWidgets called SQL_C_WXCHAR has been introduced.
|
- A new data type specific to wxWidgets called SQL_C_WXCHAR has been introduced.
|
||||||
SQL_C_WXCHAR should be used rather than SQL_C_CHAR to ensure transparent
|
SQL_C_WXCHAR should be used rather than SQL_C_CHAR to ensure transparent
|
||||||
behavior between Unicode and non-unicode builds
|
behavior between Unicode and non-unicode builds
|
||||||
- BLOB example added to samples\db (thanks to Casey ODonnell)
|
- BLOB example added to samples/db (thanks to Casey ODonnell)
|
||||||
- use wxStream::GetLength() instead of deprecated GetSize()
|
- use wxStream::GetLength() instead of deprecated GetSize()
|
||||||
- wxGetOsDescription() is now more precise (Olly Betts)
|
- wxGetOsDescription() is now more precise (Olly Betts)
|
||||||
|
- XRC supports system fonts and colours (Ray Gilbert)
|
||||||
|
|
||||||
All (GUI):
|
All (GUI):
|
||||||
|
|
||||||
|
@ -226,6 +226,55 @@ Boolean
|
|||||||
Boolean value, either "0" (false) or "1" (true).
|
Boolean value, either "0" (false) or "1" (true).
|
||||||
|
|
||||||
|
|
||||||
|
Font
|
||||||
|
----
|
||||||
|
Font value. A font can be described either in terms of its elementary
|
||||||
|
properties, or it can be derived from one of system fonts. The font node
|
||||||
|
may contain following subnodes (the table lists subnode name on the left and
|
||||||
|
variable type as per the definitions above on the right side):
|
||||||
|
|
||||||
|
size UnsignedInteger
|
||||||
|
style normal | italic | slant
|
||||||
|
weight normal | bold | light
|
||||||
|
family roman | script | decorative | swiss | modern | teletype
|
||||||
|
underlined Boolean
|
||||||
|
face comma-separated list of faces
|
||||||
|
encoding charset of the font (meaningless in Unicode build), as string
|
||||||
|
sysfont symbolic name of system standard font
|
||||||
|
(one of wxSYS_*_FONT constants)
|
||||||
|
relativesize Float, font size relative to choosen system font's size;
|
||||||
|
can only be used when 'sysfont' is used and when 'size' is not
|
||||||
|
used
|
||||||
|
|
||||||
|
All of them are optional, if they are missing, wxFont default is used.
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
|
||||||
|
<font>
|
||||||
|
<face>arial,helvetica</face>
|
||||||
|
<size>12</size>
|
||||||
|
</font>
|
||||||
|
|
||||||
|
<font>
|
||||||
|
<sysfont>wxSYS_DEFAULT_GUI_FONT</sysfont>
|
||||||
|
<weight>bold</weight>
|
||||||
|
<relativesize>1.5</relativesize>
|
||||||
|
</font>
|
||||||
|
|
||||||
|
|
||||||
|
Colour
|
||||||
|
------
|
||||||
|
A colour value is either explicit RGB value in the standard #rrggbb format
|
||||||
|
where rr, gg and bb are hexadecimal case-insensitive values in the 00..FF
|
||||||
|
range, or a symbolic name. Symbolic names are wxSYS_COLOUR_* constants defined
|
||||||
|
by wxWidgets, written as strings.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
<bg>wxSYS_COLOUR_SCROLLBAR</bg>
|
||||||
|
<fg>#FF0000</fg>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
4. Supported classes
|
4. Supported classes
|
||||||
====================
|
====================
|
||||||
|
@ -387,8 +387,11 @@ protected:
|
|||||||
// Gets a bool flag (1, t, yes, on, true are true, everything else is false).
|
// Gets a bool flag (1, t, yes, on, true are true, everything else is false).
|
||||||
bool GetBool(const wxString& param, bool defaultv = false);
|
bool GetBool(const wxString& param, bool defaultv = false);
|
||||||
|
|
||||||
// Gets the integer value from the parameter.
|
// Gets an integer value from the parameter.
|
||||||
long GetLong( const wxString& param, long defaultv = 0 );
|
long GetLong(const wxString& param, long defaultv = 0);
|
||||||
|
|
||||||
|
// Gets a float value from the parameter.
|
||||||
|
float GetFloat(const wxString& param, float defaultv = 0);
|
||||||
|
|
||||||
// Gets colour in HTML syntax (#RRGGBB).
|
// Gets colour in HTML syntax (#RRGGBB).
|
||||||
wxColour GetColour(const wxString& param);
|
wxColour GetColour(const wxString& param);
|
||||||
|
@ -21,6 +21,8 @@
|
|||||||
|
|
||||||
#if wxUSE_XRC
|
#if wxUSE_XRC
|
||||||
|
|
||||||
|
#include <locale.h>
|
||||||
|
|
||||||
#include "wx/dialog.h"
|
#include "wx/dialog.h"
|
||||||
#include "wx/panel.h"
|
#include "wx/panel.h"
|
||||||
#include "wx/frame.h"
|
#include "wx/frame.h"
|
||||||
@ -649,7 +651,6 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
wxXmlResourceHandler::wxXmlResourceHandler()
|
wxXmlResourceHandler::wxXmlResourceHandler()
|
||||||
: m_node(NULL), m_parent(NULL), m_instance(NULL),
|
: m_node(NULL), m_parent(NULL), m_instance(NULL),
|
||||||
m_parentAsWindow(NULL)
|
m_parentAsWindow(NULL)
|
||||||
@ -859,6 +860,20 @@ long wxXmlResourceHandler::GetLong(const wxString& param, long defaultv)
|
|||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
float wxXmlResourceHandler::GetFloat(const wxString& param, float defaultv)
|
||||||
|
{
|
||||||
|
double value;
|
||||||
|
wxString str1 = GetParamValue(param);
|
||||||
|
|
||||||
|
const char *prevlocale = setlocale(LC_NUMERIC, "C");
|
||||||
|
|
||||||
|
if (!str1.ToDouble(&value))
|
||||||
|
value = defaultv;
|
||||||
|
|
||||||
|
setlocale(LC_NUMERIC, prevlocale);
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int wxXmlResourceHandler::GetID()
|
int wxXmlResourceHandler::GetID()
|
||||||
@ -884,15 +899,71 @@ bool wxXmlResourceHandler::GetBool(const wxString& param, bool defaultv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static wxColour GetSystemColour(const wxString& name)
|
||||||
|
{
|
||||||
|
if (!name.empty())
|
||||||
|
{
|
||||||
|
#define SYSCLR(clr) \
|
||||||
|
if (name == _T(#clr)) return wxSystemSettings::GetColour(clr);
|
||||||
|
SYSCLR(wxSYS_COLOUR_SCROLLBAR)
|
||||||
|
SYSCLR(wxSYS_COLOUR_BACKGROUND)
|
||||||
|
SYSCLR(wxSYS_COLOUR_DESKTOP)
|
||||||
|
SYSCLR(wxSYS_COLOUR_ACTIVECAPTION)
|
||||||
|
SYSCLR(wxSYS_COLOUR_INACTIVECAPTION)
|
||||||
|
SYSCLR(wxSYS_COLOUR_MENU)
|
||||||
|
SYSCLR(wxSYS_COLOUR_WINDOW)
|
||||||
|
SYSCLR(wxSYS_COLOUR_WINDOWFRAME)
|
||||||
|
SYSCLR(wxSYS_COLOUR_MENUTEXT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_WINDOWTEXT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_CAPTIONTEXT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_ACTIVEBORDER)
|
||||||
|
SYSCLR(wxSYS_COLOUR_INACTIVEBORDER)
|
||||||
|
SYSCLR(wxSYS_COLOUR_APPWORKSPACE)
|
||||||
|
SYSCLR(wxSYS_COLOUR_HIGHLIGHT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_HIGHLIGHTTEXT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_BTNFACE)
|
||||||
|
SYSCLR(wxSYS_COLOUR_3DFACE)
|
||||||
|
SYSCLR(wxSYS_COLOUR_BTNSHADOW)
|
||||||
|
SYSCLR(wxSYS_COLOUR_3DSHADOW)
|
||||||
|
SYSCLR(wxSYS_COLOUR_GRAYTEXT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_BTNTEXT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_INACTIVECAPTIONTEXT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_BTNHIGHLIGHT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_BTNHILIGHT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_3DHIGHLIGHT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_3DHILIGHT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_3DDKSHADOW)
|
||||||
|
SYSCLR(wxSYS_COLOUR_3DLIGHT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_INFOTEXT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_INFOBK)
|
||||||
|
SYSCLR(wxSYS_COLOUR_LISTBOX)
|
||||||
|
SYSCLR(wxSYS_COLOUR_HOTLIGHT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_GRADIENTACTIVECAPTION)
|
||||||
|
SYSCLR(wxSYS_COLOUR_GRADIENTINACTIVECAPTION)
|
||||||
|
SYSCLR(wxSYS_COLOUR_MENUHILIGHT)
|
||||||
|
SYSCLR(wxSYS_COLOUR_MENUBAR)
|
||||||
|
#undef SYSCLR
|
||||||
|
}
|
||||||
|
|
||||||
|
return wxNullColour;
|
||||||
|
}
|
||||||
|
|
||||||
wxColour wxXmlResourceHandler::GetColour(const wxString& param)
|
wxColour wxXmlResourceHandler::GetColour(const wxString& param)
|
||||||
{
|
{
|
||||||
wxString v = GetParamValue(param);
|
wxString v = GetParamValue(param);
|
||||||
|
|
||||||
|
// find colour using HTML syntax (#RRGGBB)
|
||||||
unsigned long tmp = 0;
|
unsigned long tmp = 0;
|
||||||
|
|
||||||
if (v.Length() != 7 || v[0u] != wxT('#') ||
|
if (v.Length() != 7 || v[0u] != wxT('#') ||
|
||||||
wxSscanf(v.c_str(), wxT("#%lX"), &tmp) != 1)
|
wxSscanf(v.c_str(), wxT("#%lX"), &tmp) != 1)
|
||||||
{
|
{
|
||||||
|
// the colour doesn't use #RRGGBB format, check if it is symbolic
|
||||||
|
// colour name:
|
||||||
|
wxColour clr = GetSystemColour(v);
|
||||||
|
if (clr.Ok())
|
||||||
|
return clr;
|
||||||
|
|
||||||
wxLogError(_("XRC resource: Incorrect colour specification '%s' for property '%s'."),
|
wxLogError(_("XRC resource: Incorrect colour specification '%s' for property '%s'."),
|
||||||
v.c_str(), param.c_str());
|
v.c_str(), param.c_str());
|
||||||
return wxNullColour;
|
return wxNullColour;
|
||||||
@ -949,7 +1020,8 @@ wxBitmap wxXmlResourceHandler::GetBitmap(const wxString& param,
|
|||||||
|
|
||||||
if (!img.Ok())
|
if (!img.Ok())
|
||||||
{
|
{
|
||||||
wxLogError(_("XRC resource: Cannot create bitmap from '%s'."), param.c_str());
|
wxLogError(_("XRC resource: Cannot create bitmap from '%s'."),
|
||||||
|
param.c_str());
|
||||||
return wxNullBitmap;
|
return wxNullBitmap;
|
||||||
}
|
}
|
||||||
if (!(size == wxDefaultSize)) img.Rescale(size.x, size.y);
|
if (!(size == wxDefaultSize)) img.Rescale(size.x, size.y);
|
||||||
@ -1084,6 +1156,26 @@ wxCoord wxXmlResourceHandler::GetDimension(const wxString& param, wxCoord defaul
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Get system font index using indexname
|
||||||
|
static wxFont GetSystemFont(const wxString& name)
|
||||||
|
{
|
||||||
|
if (!name.empty())
|
||||||
|
{
|
||||||
|
#define SYSFNT(fnt) \
|
||||||
|
if (name == _T(#fnt)) return wxSystemSettings::GetFont(fnt);
|
||||||
|
SYSFNT(wxSYS_OEM_FIXED_FONT)
|
||||||
|
SYSFNT(wxSYS_ANSI_FIXED_FONT)
|
||||||
|
SYSFNT(wxSYS_ANSI_VAR_FONT)
|
||||||
|
SYSFNT(wxSYS_SYSTEM_FONT)
|
||||||
|
SYSFNT(wxSYS_DEVICE_DEFAULT_FONT)
|
||||||
|
SYSFNT(wxSYS_DEFAULT_PALETTE)
|
||||||
|
SYSFNT(wxSYS_SYSTEM_FIXED_FONT)
|
||||||
|
SYSFNT(wxSYS_DEFAULT_GUI_FONT)
|
||||||
|
#undef SYSFNT
|
||||||
|
}
|
||||||
|
|
||||||
|
return wxNullFont;
|
||||||
|
}
|
||||||
|
|
||||||
wxFont wxXmlResourceHandler::GetFont(const wxString& param)
|
wxFont wxXmlResourceHandler::GetFont(const wxString& param)
|
||||||
{
|
{
|
||||||
@ -1097,36 +1189,62 @@ wxFont wxXmlResourceHandler::GetFont(const wxString& param)
|
|||||||
wxXmlNode *oldnode = m_node;
|
wxXmlNode *oldnode = m_node;
|
||||||
m_node = font_node;
|
m_node = font_node;
|
||||||
|
|
||||||
long size = GetLong(wxT("size"), 12);
|
// font attributes:
|
||||||
|
|
||||||
|
// size
|
||||||
|
int isize = wxDEFAULT;
|
||||||
|
bool hasSize = HasParam(wxT("size"));
|
||||||
|
if (hasSize)
|
||||||
|
isize = GetLong(wxT("size"), wxDEFAULT);
|
||||||
|
|
||||||
|
// style
|
||||||
|
int istyle = wxNORMAL;
|
||||||
|
bool hasStyle = HasParam(wxT("style"));
|
||||||
|
if (hasStyle)
|
||||||
|
{
|
||||||
wxString style = GetParamValue(wxT("style"));
|
wxString style = GetParamValue(wxT("style"));
|
||||||
wxString weight = GetParamValue(wxT("weight"));
|
if (style == wxT("italic"))
|
||||||
int istyle = wxNORMAL, iweight = wxNORMAL;
|
istyle = wxITALIC;
|
||||||
if (style == wxT("italic")) istyle = wxITALIC;
|
else if (style == wxT("slant"))
|
||||||
else if (style == wxT("slant")) istyle = wxSLANT;
|
istyle = wxSLANT;
|
||||||
if (weight == wxT("bold")) iweight = wxBOLD;
|
}
|
||||||
else if (weight == wxT("light")) iweight = wxLIGHT;
|
|
||||||
|
|
||||||
wxString family = GetParamValue(wxT("family"));
|
// weight
|
||||||
|
int iweight = wxNORMAL;
|
||||||
|
bool hasWeight = HasParam(wxT("weight"));
|
||||||
|
if (hasWeight)
|
||||||
|
{
|
||||||
|
wxString weight = GetParamValue(wxT("weight"));
|
||||||
|
if (weight == wxT("bold"))
|
||||||
|
iweight = wxBOLD;
|
||||||
|
else if (weight == wxT("light"))
|
||||||
|
iweight = wxLIGHT;
|
||||||
|
}
|
||||||
|
|
||||||
|
// underline
|
||||||
|
bool hasUnderlined = HasParam(wxT("underlined"));
|
||||||
|
bool underlined = hasUnderlined ? GetBool(wxT("underlined"), false) : false;
|
||||||
|
|
||||||
|
// family and facename
|
||||||
int ifamily = wxDEFAULT;
|
int ifamily = wxDEFAULT;
|
||||||
|
bool hasFamily = HasParam(wxT("family"));
|
||||||
|
if (hasFamily)
|
||||||
|
{
|
||||||
|
wxString family = GetParamValue(wxT("family"));
|
||||||
if (family == wxT("decorative")) ifamily = wxDECORATIVE;
|
if (family == wxT("decorative")) ifamily = wxDECORATIVE;
|
||||||
else if (family == wxT("roman")) ifamily = wxROMAN;
|
else if (family == wxT("roman")) ifamily = wxROMAN;
|
||||||
else if (family == wxT("script")) ifamily = wxSCRIPT;
|
else if (family == wxT("script")) ifamily = wxSCRIPT;
|
||||||
else if (family == wxT("swiss")) ifamily = wxSWISS;
|
else if (family == wxT("swiss")) ifamily = wxSWISS;
|
||||||
else if (family == wxT("modern")) ifamily = wxMODERN;
|
else if (family == wxT("modern")) ifamily = wxMODERN;
|
||||||
|
else if (family == wxT("teletype")) ifamily = wxTELETYPE;
|
||||||
|
}
|
||||||
|
|
||||||
bool underlined = GetBool(wxT("underlined"), false);
|
|
||||||
|
|
||||||
wxString encoding = GetParamValue(wxT("encoding"));
|
|
||||||
wxFontMapper mapper;
|
|
||||||
wxFontEncoding enc = wxFONTENCODING_DEFAULT;
|
|
||||||
if (!encoding.IsEmpty())
|
|
||||||
enc = mapper.CharsetToEncoding(encoding);
|
|
||||||
if (enc == wxFONTENCODING_SYSTEM)
|
|
||||||
enc = wxFONTENCODING_DEFAULT;
|
|
||||||
|
|
||||||
|
wxString facename;
|
||||||
|
bool hasFacename = HasParam(wxT("face"));
|
||||||
|
if (hasFacename)
|
||||||
|
{
|
||||||
wxString faces = GetParamValue(wxT("face"));
|
wxString faces = GetParamValue(wxT("face"));
|
||||||
wxString facename = wxEmptyString;
|
|
||||||
wxFontEnumerator enu;
|
wxFontEnumerator enu;
|
||||||
enu.EnumerateFacenames();
|
enu.EnumerateFacenames();
|
||||||
wxStringTokenizer tk(faces, wxT(","));
|
wxStringTokenizer tk(faces, wxT(","));
|
||||||
@ -1139,11 +1257,54 @@ wxFont wxXmlResourceHandler::GetFont(const wxString& param)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// encoding
|
||||||
|
wxFontEncoding enc = wxFONTENCODING_DEFAULT;
|
||||||
|
bool hasEncoding = HasParam(wxT("encoding"));
|
||||||
|
if (hasEncoding)
|
||||||
|
{
|
||||||
|
wxString encoding = GetParamValue(wxT("encoding"));
|
||||||
|
wxFontMapper mapper;
|
||||||
|
if (!encoding.IsEmpty())
|
||||||
|
enc = mapper.CharsetToEncoding(encoding);
|
||||||
|
if (enc == wxFONTENCODING_SYSTEM)
|
||||||
|
enc = wxFONTENCODING_DEFAULT;
|
||||||
|
}
|
||||||
|
|
||||||
|
// is this font based on a system font?
|
||||||
|
wxFont sysfont = GetSystemFont(GetParamValue(wxT("sysfont")));
|
||||||
|
|
||||||
|
if (sysfont.Ok())
|
||||||
|
{
|
||||||
|
if (hasSize)
|
||||||
|
sysfont.SetPointSize(isize);
|
||||||
|
else if (HasParam(wxT("relativesize")))
|
||||||
|
sysfont.SetPointSize(int(sysfont.GetPointSize() *
|
||||||
|
GetFloat(wxT("relativesize"))));
|
||||||
|
|
||||||
|
if (hasStyle)
|
||||||
|
sysfont.SetStyle(istyle);
|
||||||
|
if (hasWeight)
|
||||||
|
sysfont.SetWeight(iweight);
|
||||||
|
if (hasUnderlined)
|
||||||
|
sysfont.SetUnderlined(underlined);
|
||||||
|
if (hasFamily)
|
||||||
|
sysfont.SetFamily(ifamily);
|
||||||
|
if (hasFacename)
|
||||||
|
sysfont.SetFaceName(facename);
|
||||||
|
if (hasEncoding)
|
||||||
|
sysfont.SetDefaultEncoding(enc);
|
||||||
|
|
||||||
m_node = oldnode;
|
m_node = oldnode;
|
||||||
|
return sysfont;
|
||||||
wxFont font(size, ifamily, istyle, iweight, underlined, facename, enc);
|
}
|
||||||
return font;
|
else
|
||||||
|
{
|
||||||
|
m_node = oldnode;
|
||||||
|
return wxFont(isize, ifamily, istyle, iweight,
|
||||||
|
underlined, facename, enc);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user