diff options
author | Jing Bai <jing.bai@digia.com> | 2012-12-11 15:20:16 +0100 |
---|---|---|
committer | The Qt Project <gerrit-noreply@qt-project.org> | 2012-12-12 23:34:19 +0100 |
commit | e1cbc8c68f5c88038b4f88f1b852fe36f8c78b45 (patch) | |
tree | 568f8b7b8871e5a07ca4b8e919e21bbe30b75a60 /examples/widgets/tools | |
parent | 6797413db25b54638c879020e2af552f6e61bcf6 (diff) |
add auto-detect system language in i18n example
It makes this example more complete since we move
linguist related examples into qttools
Task-number: QTBUG-28434
Change-Id: Ic6bbbd2702b5a0a304b5e8ce59da37ef95e4b42e
Reviewed-by: Marc Mutz <marc.mutz@kdab.com>
Diffstat (limited to 'examples/widgets/tools')
-rw-r--r-- | examples/widgets/tools/i18n/languagechooser.cpp | 12 | ||||
-rw-r--r-- | examples/widgets/tools/i18n/languagechooser.h | 3 | ||||
-rw-r--r-- | examples/widgets/tools/i18n/main.cpp | 4 |
3 files changed, 15 insertions, 4 deletions
diff --git a/examples/widgets/tools/i18n/languagechooser.cpp b/examples/widgets/tools/i18n/languagechooser.cpp index 0728e29547..2bd1de4f1e 100644 --- a/examples/widgets/tools/i18n/languagechooser.cpp +++ b/examples/widgets/tools/i18n/languagechooser.cpp @@ -49,7 +49,7 @@ extern void qt_mac_set_menubar_merge(bool merge); QT_END_NAMESPACE #endif -LanguageChooser::LanguageChooser(QWidget *parent) +LanguageChooser::LanguageChooser(const QString& defaultLang, QWidget *parent) : QDialog(parent, Qt::WindowStaysOnTopHint) { groupBox = new QGroupBox("Languages"); @@ -61,6 +61,8 @@ LanguageChooser::LanguageChooser(QWidget *parent) QCheckBox *checkBox = new QCheckBox(languageName(qmFiles[i])); qmFileForCheckBoxMap.insert(checkBox, qmFiles[i]); connect(checkBox, SIGNAL(toggled(bool)), this, SLOT(checkBoxToggled())); + if (languageMatch(defaultLang, qmFiles[i])) + checkBox->setCheckState(Qt::Checked); groupBoxLayout->addWidget(checkBox, i / 2, i % 2); } groupBox->setLayout(groupBoxLayout); @@ -87,6 +89,14 @@ LanguageChooser::LanguageChooser(QWidget *parent) setWindowTitle("I18N"); } +bool LanguageChooser::languageMatch(const QString& lang, const QString& qmFile) +{ + //qmFile: i18n_xx.qm + const QString prefix = "i18n_"; + const int langTokenLength = 2; /*FIXME: is checking two chars enough?*/ + return qmFile.midRef(qmFile.indexOf(prefix) + prefix.length(), langTokenLength) == lang.leftRef(langTokenLength); +} + bool LanguageChooser::eventFilter(QObject *object, QEvent *event) { if (event->type() == QEvent::Close) { diff --git a/examples/widgets/tools/i18n/languagechooser.h b/examples/widgets/tools/i18n/languagechooser.h index 4d350674e5..8cbf1e67c3 100644 --- a/examples/widgets/tools/i18n/languagechooser.h +++ b/examples/widgets/tools/i18n/languagechooser.h @@ -58,7 +58,7 @@ class LanguageChooser : public QDialog Q_OBJECT public: - LanguageChooser(QWidget *parent = 0); + explicit LanguageChooser(const QString& defaultLang = QString(), QWidget *parent = 0); protected: bool eventFilter(QObject *object, QEvent *event); @@ -73,6 +73,7 @@ private: QStringList findQmFiles(); QString languageName(const QString &qmFile); QColor colorForLanguage(const QString &language); + static bool languageMatch(const QString& lang, const QString& qmFile); QGroupBox *groupBox; QDialogButtonBox *buttonBox; diff --git a/examples/widgets/tools/i18n/main.cpp b/examples/widgets/tools/i18n/main.cpp index f57f2b4b2e..09213a69bb 100644 --- a/examples/widgets/tools/i18n/main.cpp +++ b/examples/widgets/tools/i18n/main.cpp @@ -39,7 +39,7 @@ ****************************************************************************/ #include <QApplication> - +#include <QLocale> #include "languagechooser.h" #include "mainwindow.h" @@ -48,7 +48,7 @@ int main(int argc, char *argv[]) Q_INIT_RESOURCE(i18n); QApplication app(argc, argv); - LanguageChooser chooser; + LanguageChooser chooser(QLocale::system().name()); chooser.show(); return app.exec(); } |