blob: 260609112fde349bd7ceb1951d7bc5c78f6f97e6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
/****************************************************************************
**
** Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies).
** Contact: Qt Software Information (qt-info@nokia.com)
**
** This file is part of the $MODULE$ of the Qt Toolkit.
**
** $TROLLTECH_DUAL_EMBEDDED_LICENSE$
**
****************************************************************************/
#include "qfont.h"
#include "qt_s60_p.h"
#include <private/qwindowsurface_s60_p.h>
#include "qmutex.h"
QT_BEGIN_NAMESPACE
#if 1
#ifdef QT_NO_FREETYPE
Q_GLOBAL_STATIC(QMutex, lastResortFamilyMutex);
#endif // QT_NO_FREETYPE
QString QFont::lastResortFamily() const
{
#ifdef QT_NO_FREETYPE
QMutexLocker locker(lastResortFamilyMutex());
static QString family;
if (family.isEmpty()) {
QS60WindowSurface::unlockBitmapHeap();
CFont *font;
const TInt err = S60->screenDevice()->GetNearestFontInTwips(font, TFontSpec());
Q_ASSERT(err == KErrNone);
const TFontSpec spec = font->FontSpecInTwips();
family = QString((const QChar *)spec.iTypeface.iName.Ptr(), spec.iTypeface.iName.Length());
S60->screenDevice()->ReleaseFont(font);
QS60WindowSurface::lockBitmapHeap();
}
return family;
#else
// For the FreeType case we just hard code the face name, since otherwise on
// East Asian systems we may get a name for a stroke based (non-ttf) font.
// TODO: Get the type face name in a proper way
const bool isJapaneseOrChineseSystem =
User::Language() == ELangJapanese || User::Language() == ELangPrcChinese;
return QLatin1String(isJapaneseOrChineseSystem?"Heisei Kaku Gothic S60":"Series 60 Sans");
#endif // QT_NO_FREETYPE
}
#else // 0
QString QFont::lastResortFamily() const
{
return QLatin1String("Series 60 Sans");
}
#endif // 0
QString QFont::defaultFamily() const
{
return lastResortFamily();
}
QT_END_NAMESPACE
|