[Interest] Dynamic translations for mobile apps at runtime?

Jason H jhihn at gmx.com
Tue Mar 8 23:21:22 CET 2016


Sounds like there should be a qApp->translations() that we can use to remove all currently installed translations? Without it, we have to do what you do. 


> Sent: Tuesday, March 08, 2016 at 3:44 PM
> From: Gianluca <gmaxera at gmail.com>
> To: "Jason H" <jhihn at gmx.com>
> Cc: "interest at qt-project.org" <interest at qt-project.org>
> Subject: Re: [Interest] Dynamic translations for mobile apps at runtime?
>
> qApp->installTranslator add a new translation into the stack. Does not remove the old ones.
> So, if the user click 10 times: Italian - English - Italian - English … etc…
> you got ten translator into the memory.
> That’s because the translation is searched into the order on which the translator are installed into the stack.
> 
> That’s why I remove everything so there is only one translators at time into the memory.
> 
> Il giorno 08/mar/2016, alle ore 18:46, Jason H <jhihn at gmx.com> ha scritto:
> 
> > I'm wondering why you load all those languages and then remove all but one of them? Being a mobile app, I have to be somewhat conscience of memory foot print. Do you see anything wrong with:
> > 
> > void Backend::selectLanguage( QString language ) {
> >    translator = new QTranslator(this);
> >    translator->load( language, commonPath()+"/translations" );
> >    qApp->installTranslator(translator);
> > }
> > 
> > ?
> > 
> > 
> >> Hello Jason,
> >> I got the same issue some times ago … and I found that it’s possible to use the translation feature of Qt … that seems static, but it’s not.
> >> And localize.biz it’s a wonderful site that allow you to modify Qt translation files directly on web and download the updated one.
> >> 
> >> The trick to achieve (summarized) is the following:
> >> Somewhere in your code maintain and update from remote an array of Translators:
> >> 	translators["en"] = new QTranslator(this);
> >> 	translators["en"]->load( "tr_en", commonPath()+"/translations" );
> >> 	translators["de"] = new QTranslator(this);
> >> 	translators["de"]->load( "tr_de", commonPath()+"/translations" );
> >> 	translators["fr"] = new QTranslator(this);
> >> 	translators["fr"]->load( "tr_fr", commonPath()+"/translations" );
> >> 	translators["ru"] = new QTranslator(this);
> >> 	translators["ru"]->load( "tr_ru", commonPath()+"/translations" );
> >> You can change these entry with new files downloaded at runtime.
> >> 
> >> Then you implement a method that you call at runtime for changing the translator, something like that:
> >> 
> >> void Backend::selectLanguage( QString language ) {
> >> 	foreach( QString lang, translators.keys() ) {
> >> 		if ( lang == language ) {
> >> 			qApp->installTranslator( translators[lang] );
> >> 		} else {
> >> 			qApp->removeTranslator( translators[lang] );
> >> 		}
> >> 	}
> >> 	this->language = language;
> >> 	emit languageChanged();
> >> }
> >> And then there is the final trick:
> >> You create a “fake” property that is always an empty string but it’s binded to languageChanged signal:
> >> 
> >> Q_PROPERTY( QString es READ getES NOTIFY languageChanged )
> >> 
> >> And (the most annoying part), append this empty string to all string you want to change at runtime like that:
> >> 
> >> qsTr("NEWS<br/>HUB")+backend.es
> >> 
> >> And close the loop.
> >> 
> >> What will happen is the following: the translator change at runtime and you trigger a languageChanged that trigger an update of all string that got backend.es appended that trigger the call of qsTr that take the new translation from the new translator.
> >> 
> 
>



More information about the Interest mailing list