fixed restoring fonts from the native font info data which was completely broken somehow
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@16937 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
168
src/gtk/font.cpp
168
src/gtk/font.cpp
@@ -41,15 +41,11 @@
|
|||||||
static const int wxDEFAULT_FONT_SIZE = 12;
|
static const int wxDEFAULT_FONT_SIZE = 12;
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxScaledFontList
|
// wxScaledFontList: maps the font sizes to the GDK fonts for the given font
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
// TODO: replace this with a type safe list or hash!!
|
WX_DECLARE_HASH_MAP(int, GdkFont *, wxIntegerHash, wxIntegerEqual,
|
||||||
class wxScaledFontList : public wxList
|
wxScaledFontList);
|
||||||
{
|
|
||||||
public:
|
|
||||||
wxScaledFontList() : wxList(wxKEY_INTEGER) { }
|
|
||||||
};
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxFontRefData
|
// wxFontRefData
|
||||||
@@ -79,10 +75,12 @@ public:
|
|||||||
bool HasNativeFont() const
|
bool HasNativeFont() const
|
||||||
{
|
{
|
||||||
#ifdef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
return TRUE; // ?
|
// we always have a Pango font description
|
||||||
#else
|
return TRUE;
|
||||||
|
#else // GTK 1.x
|
||||||
|
// only use m_nativeFontInfo if it had been initialized
|
||||||
return !m_nativeFontInfo.IsDefault();
|
return !m_nativeFontInfo.IsDefault();
|
||||||
#endif
|
#endif // GTK 2.0/1.x
|
||||||
}
|
}
|
||||||
|
|
||||||
// setters: all of them also take care to modify m_nativeFontInfo if we
|
// setters: all of them also take care to modify m_nativeFontInfo if we
|
||||||
@@ -95,6 +93,9 @@ public:
|
|||||||
void SetFaceName(const wxString& facename);
|
void SetFaceName(const wxString& facename);
|
||||||
void SetEncoding(wxFontEncoding encoding);
|
void SetEncoding(wxFontEncoding encoding);
|
||||||
|
|
||||||
|
// and this one also modifies all the other font data fields
|
||||||
|
void SetNativeFontInfo(const wxNativeFontInfo& info);
|
||||||
|
|
||||||
// debugger helper: shows what the font really is
|
// debugger helper: shows what the font really is
|
||||||
//
|
//
|
||||||
// VZ: I need this as my gdb either shows wildly wrong values or crashes
|
// VZ: I need this as my gdb either shows wildly wrong values or crashes
|
||||||
@@ -125,11 +126,19 @@ protected:
|
|||||||
const wxString& faceName,
|
const wxString& faceName,
|
||||||
wxFontEncoding encoding);
|
wxFontEncoding encoding);
|
||||||
|
|
||||||
|
// set all fields from (already initialized and valid) m_nativeFontInfo
|
||||||
|
void InitFromNative();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
#ifndef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
|
void ClearGdkFonts() { }
|
||||||
|
#else // GTK 1.x
|
||||||
|
// clear m_scaled_xfonts
|
||||||
|
void ClearGdkFonts();
|
||||||
|
|
||||||
// the map of font sizes to "GdkFont *"
|
// the map of font sizes to "GdkFont *"
|
||||||
wxScaledFontList m_scaled_xfonts;
|
wxScaledFontList m_scaled_xfonts;
|
||||||
#endif
|
#endif // GTK 2.0/1.x
|
||||||
|
|
||||||
// the broken down font parameters
|
// the broken down font parameters
|
||||||
int m_pointSize;
|
int m_pointSize;
|
||||||
@@ -173,8 +182,9 @@ void wxFontRefData::Init(int pointSize,
|
|||||||
|
|
||||||
// and here, do we really want to forbid creation of the font of the size
|
// and here, do we really want to forbid creation of the font of the size
|
||||||
// 90 (the value of wxDEFAULT)??
|
// 90 (the value of wxDEFAULT)??
|
||||||
m_pointSize = pointSize == wxDEFAULT ||
|
m_pointSize = pointSize == wxDEFAULT || pointSize == -1
|
||||||
pointSize == -1 ? wxDEFAULT_FONT_SIZE : pointSize;
|
? wxDEFAULT_FONT_SIZE
|
||||||
|
: pointSize;
|
||||||
|
|
||||||
m_underlined = underlined;
|
m_underlined = underlined;
|
||||||
m_encoding = encoding;
|
m_encoding = encoding;
|
||||||
@@ -200,38 +210,12 @@ void wxFontRefData::Init(int pointSize,
|
|||||||
SetStyle( m_style );
|
SetStyle( m_style );
|
||||||
SetPointSize( m_pointSize );
|
SetPointSize( m_pointSize );
|
||||||
SetWeight( m_weight );
|
SetWeight( m_weight );
|
||||||
#endif
|
#endif // GTK 2.0
|
||||||
}
|
}
|
||||||
|
|
||||||
wxFontRefData::wxFontRefData( const wxFontRefData& data )
|
void wxFontRefData::InitFromNative()
|
||||||
: wxObjectRefData()
|
|
||||||
{
|
|
||||||
m_pointSize = data.m_pointSize;
|
|
||||||
m_family = data.m_family;
|
|
||||||
m_style = data.m_style;
|
|
||||||
m_weight = data.m_weight;
|
|
||||||
|
|
||||||
m_underlined = data.m_underlined;
|
|
||||||
|
|
||||||
m_faceName = data.m_faceName;
|
|
||||||
m_encoding = data.m_encoding;
|
|
||||||
|
|
||||||
m_nativeFontInfo = data.m_nativeFontInfo;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxFontRefData::wxFontRefData(int size, int family, int style,
|
|
||||||
int weight, bool underlined,
|
|
||||||
const wxString& faceName,
|
|
||||||
wxFontEncoding encoding)
|
|
||||||
{
|
|
||||||
Init(size, family, style, weight, underlined, faceName, encoding);
|
|
||||||
}
|
|
||||||
|
|
||||||
wxFontRefData::wxFontRefData(const wxString& fontname)
|
|
||||||
{
|
{
|
||||||
#ifdef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
m_nativeFontInfo.FromString( fontname );
|
|
||||||
|
|
||||||
// Get native info
|
// Get native info
|
||||||
PangoFontDescription *desc = m_nativeFontInfo.description;
|
PangoFontDescription *desc = m_nativeFontInfo.description;
|
||||||
|
|
||||||
@@ -293,10 +277,7 @@ wxFontRefData::wxFontRefData(const wxString& fontname)
|
|||||||
|
|
||||||
// Cannot we choose that
|
// Cannot we choose that
|
||||||
m_encoding = wxFONTENCODING_SYSTEM;
|
m_encoding = wxFONTENCODING_SYSTEM;
|
||||||
#else
|
#else // GTK 1.x
|
||||||
// remember the X font name
|
|
||||||
m_nativeFontInfo.SetXFontName(fontname);
|
|
||||||
|
|
||||||
// get the font parameters from the XLFD
|
// get the font parameters from the XLFD
|
||||||
// -------------------------------------
|
// -------------------------------------
|
||||||
|
|
||||||
@@ -391,24 +372,66 @@ wxFontRefData::wxFontRefData(const wxString& fontname)
|
|||||||
}
|
}
|
||||||
else // unknown encoding
|
else // unknown encoding
|
||||||
{
|
{
|
||||||
// may be give a warning here?
|
// may be give a warning here? or use wxFontMapper?
|
||||||
m_encoding = wxFONTENCODING_SYSTEM;
|
m_encoding = wxFONTENCODING_SYSTEM;
|
||||||
}
|
}
|
||||||
#endif
|
#endif // GTK 2.0/1.x
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxFontRefData::wxFontRefData( const wxFontRefData& data )
|
||||||
|
: wxObjectRefData()
|
||||||
|
{
|
||||||
|
m_pointSize = data.m_pointSize;
|
||||||
|
m_family = data.m_family;
|
||||||
|
m_style = data.m_style;
|
||||||
|
m_weight = data.m_weight;
|
||||||
|
|
||||||
|
m_underlined = data.m_underlined;
|
||||||
|
|
||||||
|
m_faceName = data.m_faceName;
|
||||||
|
m_encoding = data.m_encoding;
|
||||||
|
|
||||||
|
m_nativeFontInfo = data.m_nativeFontInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxFontRefData::wxFontRefData(int size, int family, int style,
|
||||||
|
int weight, bool underlined,
|
||||||
|
const wxString& faceName,
|
||||||
|
wxFontEncoding encoding)
|
||||||
|
{
|
||||||
|
Init(size, family, style, weight, underlined, faceName, encoding);
|
||||||
|
}
|
||||||
|
|
||||||
|
wxFontRefData::wxFontRefData(const wxString& fontname)
|
||||||
|
{
|
||||||
|
// VZ: FromString() should really work in both cases, doesn't it?
|
||||||
|
#ifdef __WXGTK20__
|
||||||
|
m_nativeFontInfo.FromString( fontname );
|
||||||
|
#else // GTK 1.x
|
||||||
|
m_nativeFontInfo.SetXFontName(fontname);
|
||||||
|
#endif // GTK 2.0/1.x
|
||||||
|
|
||||||
|
InitFromNative();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef __WXGTK20__
|
||||||
|
void wxFontRefData::ClearGdkFonts()
|
||||||
|
{
|
||||||
|
for ( wxScaledFontList::iterator i = m_scaled_xfonts.begin();
|
||||||
|
i != m_scaled_xfonts.end();
|
||||||
|
++i )
|
||||||
|
{
|
||||||
|
GdkFont *font = i->second;
|
||||||
|
gdk_font_unref( font );
|
||||||
|
}
|
||||||
|
|
||||||
|
m_scaled_xfonts.clear();
|
||||||
|
}
|
||||||
|
#endif // GTK 1.x
|
||||||
|
|
||||||
wxFontRefData::~wxFontRefData()
|
wxFontRefData::~wxFontRefData()
|
||||||
{
|
{
|
||||||
#ifndef __WXGTK20__
|
ClearGdkFonts();
|
||||||
wxNode *node = m_scaled_xfonts.First();
|
|
||||||
while (node)
|
|
||||||
{
|
|
||||||
GdkFont *font = (GdkFont*)node->Data();
|
|
||||||
wxNode *next = node->Next();
|
|
||||||
gdk_font_unref( font );
|
|
||||||
node = next;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -563,6 +586,17 @@ void wxFontRefData::SetEncoding(wxFontEncoding encoding)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxFontRefData::SetNativeFontInfo(const wxNativeFontInfo& info)
|
||||||
|
{
|
||||||
|
// previously cached fonts shouldn't be used
|
||||||
|
ClearGdkFonts();
|
||||||
|
|
||||||
|
m_nativeFontInfo = info;
|
||||||
|
|
||||||
|
// set all the other font parameters from the native font info
|
||||||
|
InitFromNative();
|
||||||
|
}
|
||||||
|
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
// wxFont implementation
|
// wxFont implementation
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
@@ -784,7 +818,7 @@ void wxFont::SetNativeFontInfo(const wxNativeFontInfo& info)
|
|||||||
{
|
{
|
||||||
Unshare();
|
Unshare();
|
||||||
|
|
||||||
M_FONTDATA->m_nativeFontInfo = info;
|
M_FONTDATA->SetNativeFontInfo(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -834,18 +868,20 @@ GdkFont *wxFont::GetInternalFont( float scale ) const
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
PangoFontDescription *font_description = GetNativeFontInfo()->description;
|
PangoFontDescription *
|
||||||
|
font_description = GetNativeFontInfo()->description;
|
||||||
|
|
||||||
font = gdk_font_from_description( font_description );
|
font = gdk_font_from_description( font_description );
|
||||||
}
|
}
|
||||||
#else
|
#else // GTK 1.x
|
||||||
long int_scale = long(scale * 100.0 + 0.5); // key for fontlist
|
long int_scale = long(scale * 100.0 + 0.5); // key for fontlist
|
||||||
int point_scale = (int)((M_FONTDATA->m_pointSize * 10 * int_scale) / 100);
|
int point_scale = (int)((M_FONTDATA->m_pointSize * 10 * int_scale) / 100);
|
||||||
|
|
||||||
wxNode *node = M_FONTDATA->m_scaled_xfonts.Find(int_scale);
|
wxScaledFontList& list = M_FONTDATA->m_scaled_xfonts;
|
||||||
if (node)
|
wxScaledFontList::iterator i = list.find(int_scale);
|
||||||
|
if ( i != list.end() )
|
||||||
{
|
{
|
||||||
font = (GdkFont*)node->Data();
|
font = i->second;
|
||||||
}
|
}
|
||||||
else // we don't have this font in this size yet
|
else // we don't have this font in this size yet
|
||||||
{
|
{
|
||||||
@@ -883,10 +919,10 @@ GdkFont *wxFont::GetInternalFont( float scale ) const
|
|||||||
|
|
||||||
if ( font )
|
if ( font )
|
||||||
{
|
{
|
||||||
M_FONTDATA->m_scaled_xfonts.Append( int_scale, (wxObject*)font );
|
list[int_scale] = font;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif // GTK 2.0
|
#endif // GTK 2.0/1.x
|
||||||
|
|
||||||
// it's quite useless to make it a wxCHECK because we're going to crash
|
// it's quite useless to make it a wxCHECK because we're going to crash
|
||||||
// anyhow...
|
// anyhow...
|
||||||
|
@@ -41,15 +41,11 @@
|
|||||||
static const int wxDEFAULT_FONT_SIZE = 12;
|
static const int wxDEFAULT_FONT_SIZE = 12;
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxScaledFontList
|
// wxScaledFontList: maps the font sizes to the GDK fonts for the given font
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
// TODO: replace this with a type safe list or hash!!
|
WX_DECLARE_HASH_MAP(int, GdkFont *, wxIntegerHash, wxIntegerEqual,
|
||||||
class wxScaledFontList : public wxList
|
wxScaledFontList);
|
||||||
{
|
|
||||||
public:
|
|
||||||
wxScaledFontList() : wxList(wxKEY_INTEGER) { }
|
|
||||||
};
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxFontRefData
|
// wxFontRefData
|
||||||
@@ -79,10 +75,12 @@ public:
|
|||||||
bool HasNativeFont() const
|
bool HasNativeFont() const
|
||||||
{
|
{
|
||||||
#ifdef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
return TRUE; // ?
|
// we always have a Pango font description
|
||||||
#else
|
return TRUE;
|
||||||
|
#else // GTK 1.x
|
||||||
|
// only use m_nativeFontInfo if it had been initialized
|
||||||
return !m_nativeFontInfo.IsDefault();
|
return !m_nativeFontInfo.IsDefault();
|
||||||
#endif
|
#endif // GTK 2.0/1.x
|
||||||
}
|
}
|
||||||
|
|
||||||
// setters: all of them also take care to modify m_nativeFontInfo if we
|
// setters: all of them also take care to modify m_nativeFontInfo if we
|
||||||
@@ -95,6 +93,9 @@ public:
|
|||||||
void SetFaceName(const wxString& facename);
|
void SetFaceName(const wxString& facename);
|
||||||
void SetEncoding(wxFontEncoding encoding);
|
void SetEncoding(wxFontEncoding encoding);
|
||||||
|
|
||||||
|
// and this one also modifies all the other font data fields
|
||||||
|
void SetNativeFontInfo(const wxNativeFontInfo& info);
|
||||||
|
|
||||||
// debugger helper: shows what the font really is
|
// debugger helper: shows what the font really is
|
||||||
//
|
//
|
||||||
// VZ: I need this as my gdb either shows wildly wrong values or crashes
|
// VZ: I need this as my gdb either shows wildly wrong values or crashes
|
||||||
@@ -125,11 +126,19 @@ protected:
|
|||||||
const wxString& faceName,
|
const wxString& faceName,
|
||||||
wxFontEncoding encoding);
|
wxFontEncoding encoding);
|
||||||
|
|
||||||
|
// set all fields from (already initialized and valid) m_nativeFontInfo
|
||||||
|
void InitFromNative();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
#ifndef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
|
void ClearGdkFonts() { }
|
||||||
|
#else // GTK 1.x
|
||||||
|
// clear m_scaled_xfonts
|
||||||
|
void ClearGdkFonts();
|
||||||
|
|
||||||
// the map of font sizes to "GdkFont *"
|
// the map of font sizes to "GdkFont *"
|
||||||
wxScaledFontList m_scaled_xfonts;
|
wxScaledFontList m_scaled_xfonts;
|
||||||
#endif
|
#endif // GTK 2.0/1.x
|
||||||
|
|
||||||
// the broken down font parameters
|
// the broken down font parameters
|
||||||
int m_pointSize;
|
int m_pointSize;
|
||||||
@@ -173,8 +182,9 @@ void wxFontRefData::Init(int pointSize,
|
|||||||
|
|
||||||
// and here, do we really want to forbid creation of the font of the size
|
// and here, do we really want to forbid creation of the font of the size
|
||||||
// 90 (the value of wxDEFAULT)??
|
// 90 (the value of wxDEFAULT)??
|
||||||
m_pointSize = pointSize == wxDEFAULT ||
|
m_pointSize = pointSize == wxDEFAULT || pointSize == -1
|
||||||
pointSize == -1 ? wxDEFAULT_FONT_SIZE : pointSize;
|
? wxDEFAULT_FONT_SIZE
|
||||||
|
: pointSize;
|
||||||
|
|
||||||
m_underlined = underlined;
|
m_underlined = underlined;
|
||||||
m_encoding = encoding;
|
m_encoding = encoding;
|
||||||
@@ -200,38 +210,12 @@ void wxFontRefData::Init(int pointSize,
|
|||||||
SetStyle( m_style );
|
SetStyle( m_style );
|
||||||
SetPointSize( m_pointSize );
|
SetPointSize( m_pointSize );
|
||||||
SetWeight( m_weight );
|
SetWeight( m_weight );
|
||||||
#endif
|
#endif // GTK 2.0
|
||||||
}
|
}
|
||||||
|
|
||||||
wxFontRefData::wxFontRefData( const wxFontRefData& data )
|
void wxFontRefData::InitFromNative()
|
||||||
: wxObjectRefData()
|
|
||||||
{
|
|
||||||
m_pointSize = data.m_pointSize;
|
|
||||||
m_family = data.m_family;
|
|
||||||
m_style = data.m_style;
|
|
||||||
m_weight = data.m_weight;
|
|
||||||
|
|
||||||
m_underlined = data.m_underlined;
|
|
||||||
|
|
||||||
m_faceName = data.m_faceName;
|
|
||||||
m_encoding = data.m_encoding;
|
|
||||||
|
|
||||||
m_nativeFontInfo = data.m_nativeFontInfo;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxFontRefData::wxFontRefData(int size, int family, int style,
|
|
||||||
int weight, bool underlined,
|
|
||||||
const wxString& faceName,
|
|
||||||
wxFontEncoding encoding)
|
|
||||||
{
|
|
||||||
Init(size, family, style, weight, underlined, faceName, encoding);
|
|
||||||
}
|
|
||||||
|
|
||||||
wxFontRefData::wxFontRefData(const wxString& fontname)
|
|
||||||
{
|
{
|
||||||
#ifdef __WXGTK20__
|
#ifdef __WXGTK20__
|
||||||
m_nativeFontInfo.FromString( fontname );
|
|
||||||
|
|
||||||
// Get native info
|
// Get native info
|
||||||
PangoFontDescription *desc = m_nativeFontInfo.description;
|
PangoFontDescription *desc = m_nativeFontInfo.description;
|
||||||
|
|
||||||
@@ -293,10 +277,7 @@ wxFontRefData::wxFontRefData(const wxString& fontname)
|
|||||||
|
|
||||||
// Cannot we choose that
|
// Cannot we choose that
|
||||||
m_encoding = wxFONTENCODING_SYSTEM;
|
m_encoding = wxFONTENCODING_SYSTEM;
|
||||||
#else
|
#else // GTK 1.x
|
||||||
// remember the X font name
|
|
||||||
m_nativeFontInfo.SetXFontName(fontname);
|
|
||||||
|
|
||||||
// get the font parameters from the XLFD
|
// get the font parameters from the XLFD
|
||||||
// -------------------------------------
|
// -------------------------------------
|
||||||
|
|
||||||
@@ -391,24 +372,66 @@ wxFontRefData::wxFontRefData(const wxString& fontname)
|
|||||||
}
|
}
|
||||||
else // unknown encoding
|
else // unknown encoding
|
||||||
{
|
{
|
||||||
// may be give a warning here?
|
// may be give a warning here? or use wxFontMapper?
|
||||||
m_encoding = wxFONTENCODING_SYSTEM;
|
m_encoding = wxFONTENCODING_SYSTEM;
|
||||||
}
|
}
|
||||||
#endif
|
#endif // GTK 2.0/1.x
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxFontRefData::wxFontRefData( const wxFontRefData& data )
|
||||||
|
: wxObjectRefData()
|
||||||
|
{
|
||||||
|
m_pointSize = data.m_pointSize;
|
||||||
|
m_family = data.m_family;
|
||||||
|
m_style = data.m_style;
|
||||||
|
m_weight = data.m_weight;
|
||||||
|
|
||||||
|
m_underlined = data.m_underlined;
|
||||||
|
|
||||||
|
m_faceName = data.m_faceName;
|
||||||
|
m_encoding = data.m_encoding;
|
||||||
|
|
||||||
|
m_nativeFontInfo = data.m_nativeFontInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxFontRefData::wxFontRefData(int size, int family, int style,
|
||||||
|
int weight, bool underlined,
|
||||||
|
const wxString& faceName,
|
||||||
|
wxFontEncoding encoding)
|
||||||
|
{
|
||||||
|
Init(size, family, style, weight, underlined, faceName, encoding);
|
||||||
|
}
|
||||||
|
|
||||||
|
wxFontRefData::wxFontRefData(const wxString& fontname)
|
||||||
|
{
|
||||||
|
// VZ: FromString() should really work in both cases, doesn't it?
|
||||||
|
#ifdef __WXGTK20__
|
||||||
|
m_nativeFontInfo.FromString( fontname );
|
||||||
|
#else // GTK 1.x
|
||||||
|
m_nativeFontInfo.SetXFontName(fontname);
|
||||||
|
#endif // GTK 2.0/1.x
|
||||||
|
|
||||||
|
InitFromNative();
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef __WXGTK20__
|
||||||
|
void wxFontRefData::ClearGdkFonts()
|
||||||
|
{
|
||||||
|
for ( wxScaledFontList::iterator i = m_scaled_xfonts.begin();
|
||||||
|
i != m_scaled_xfonts.end();
|
||||||
|
++i )
|
||||||
|
{
|
||||||
|
GdkFont *font = i->second;
|
||||||
|
gdk_font_unref( font );
|
||||||
|
}
|
||||||
|
|
||||||
|
m_scaled_xfonts.clear();
|
||||||
|
}
|
||||||
|
#endif // GTK 1.x
|
||||||
|
|
||||||
wxFontRefData::~wxFontRefData()
|
wxFontRefData::~wxFontRefData()
|
||||||
{
|
{
|
||||||
#ifndef __WXGTK20__
|
ClearGdkFonts();
|
||||||
wxNode *node = m_scaled_xfonts.First();
|
|
||||||
while (node)
|
|
||||||
{
|
|
||||||
GdkFont *font = (GdkFont*)node->Data();
|
|
||||||
wxNode *next = node->Next();
|
|
||||||
gdk_font_unref( font );
|
|
||||||
node = next;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -563,6 +586,17 @@ void wxFontRefData::SetEncoding(wxFontEncoding encoding)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxFontRefData::SetNativeFontInfo(const wxNativeFontInfo& info)
|
||||||
|
{
|
||||||
|
// previously cached fonts shouldn't be used
|
||||||
|
ClearGdkFonts();
|
||||||
|
|
||||||
|
m_nativeFontInfo = info;
|
||||||
|
|
||||||
|
// set all the other font parameters from the native font info
|
||||||
|
InitFromNative();
|
||||||
|
}
|
||||||
|
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
// wxFont implementation
|
// wxFont implementation
|
||||||
// ============================================================================
|
// ============================================================================
|
||||||
@@ -784,7 +818,7 @@ void wxFont::SetNativeFontInfo(const wxNativeFontInfo& info)
|
|||||||
{
|
{
|
||||||
Unshare();
|
Unshare();
|
||||||
|
|
||||||
M_FONTDATA->m_nativeFontInfo = info;
|
M_FONTDATA->SetNativeFontInfo(info);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -834,18 +868,20 @@ GdkFont *wxFont::GetInternalFont( float scale ) const
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
PangoFontDescription *font_description = GetNativeFontInfo()->description;
|
PangoFontDescription *
|
||||||
|
font_description = GetNativeFontInfo()->description;
|
||||||
|
|
||||||
font = gdk_font_from_description( font_description );
|
font = gdk_font_from_description( font_description );
|
||||||
}
|
}
|
||||||
#else
|
#else // GTK 1.x
|
||||||
long int_scale = long(scale * 100.0 + 0.5); // key for fontlist
|
long int_scale = long(scale * 100.0 + 0.5); // key for fontlist
|
||||||
int point_scale = (int)((M_FONTDATA->m_pointSize * 10 * int_scale) / 100);
|
int point_scale = (int)((M_FONTDATA->m_pointSize * 10 * int_scale) / 100);
|
||||||
|
|
||||||
wxNode *node = M_FONTDATA->m_scaled_xfonts.Find(int_scale);
|
wxScaledFontList& list = M_FONTDATA->m_scaled_xfonts;
|
||||||
if (node)
|
wxScaledFontList::iterator i = list.find(int_scale);
|
||||||
|
if ( i != list.end() )
|
||||||
{
|
{
|
||||||
font = (GdkFont*)node->Data();
|
font = i->second;
|
||||||
}
|
}
|
||||||
else // we don't have this font in this size yet
|
else // we don't have this font in this size yet
|
||||||
{
|
{
|
||||||
@@ -883,10 +919,10 @@ GdkFont *wxFont::GetInternalFont( float scale ) const
|
|||||||
|
|
||||||
if ( font )
|
if ( font )
|
||||||
{
|
{
|
||||||
M_FONTDATA->m_scaled_xfonts.Append( int_scale, (wxObject*)font );
|
list[int_scale] = font;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif // GTK 2.0
|
#endif // GTK 2.0/1.x
|
||||||
|
|
||||||
// it's quite useless to make it a wxCHECK because we're going to crash
|
// it's quite useless to make it a wxCHECK because we're going to crash
|
||||||
// anyhow...
|
// anyhow...
|
||||||
|
@@ -385,7 +385,13 @@ bool wxNativeFontInfo::FromXFontName(const wxString& fontname)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// this should be all
|
// this should be all
|
||||||
return !tokenizer.HasMoreTokens();
|
if ( tokenizer.HasMoreTokens() )
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
// we're initialized now
|
||||||
|
m_isDefault = FALSE;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
wxString wxNativeFontInfo::GetXFontName() const
|
wxString wxNativeFontInfo::GetXFontName() const
|
||||||
|
Reference in New Issue
Block a user