![Methods Count](https://img.shields.io/badge/Methods and size-core: 77 | deps: 13224 | 21 KB-e91e63.svg)
Keep calm and stay easy with multiple language supported in your android application.
It's basic for android application to be supported multiple languages. Yeah! It's very easy because android has String Resource. Developer just had to prepare the text for different languages then android system will use itself. But frequently problem is "On-time Language Changing". Because the String Resource was designed to be depending on current device language. but if we want to change the language by click some button. It will be difficult to handle it. This problem will solved because I have created a new library to handle application language. It called "Localization Activity" library.
Watch a short demo video from YouTube or try it at Google Play
Maven
<dependency>
<groupId>com.akexorcist</groupId>
<artifactId>localizationactivity</artifactId>
<version>1.1.1</version>
</dependency>
Gradle
compile 'com.akexorcist:localizationactivity:1.1.1'
(Optional) You can exclude com.android.support:appcompat-v7
, if your project doens't use AppCompat v7 and declare this library with delegate way.
- On-time language changing supported.
- Auto setup when activity was created.
- Current language config will saved to SharedPreference automatically.
- Very easy to use it.
LocalizationActivity is extend from AppCompatActivity class. So you still can use all method from AppCompatActivity class.
(By @AleksanderMielczarek)
import android.os.Bundle;
import com.akexorcist.localizationactivity.LocalizationDelegate;
import java.util.Locale;
public class CustomLocalizationActivity extends Activity implements OnLocaleChangedListener {
private LocalizationDelegate localizationDelegate = new LocalizationDelegate(this);
@Override
public void onCreate(Bundle savedInstanceState) {
localizationDelegate.addOnLocaleChengedListener(this);
localizationDelegate.onCreate(savedInstanceState);
super.onCreate(savedInstanceState);
}
@Override
public void onResume() {
super.onResume();
localizationDelegate.onResume();
}
public final void setLanguage(String language) {
localizationDelegate.setLanguage(language);
}
public final void setLanguage(Locale locale) {
localizationDelegate.setLanguage(locale);
}
public final void setDefaultLanguage(String language) {
localizationDelegate.setDefaultLanguage(language);
}
public final void setDefaultLanguage(Locale locale) {
localizationDelegate.setDefaultLanguage(locale);
}
public final String getLanguage() {
return localizationDelegate.getLanguage();
}
public final Locale getLocale() {
return localizationDelegate.getLocale();
}
// Just override method locale change event
@Override
public void onBeforeLocaleChanged() { }
@Override
public void onAfterLocaleChanged() { }
}
This is an example.
import android.os.Bundle;
import android.view.View;
import com.akexorcist.localizationactivity.LocalizationActivity;
public class MainActivity extends LocalizationActivity implements View.OnClickListener {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_simple);
findViewById(R.id.btn_th).setOnClickListener(this);
findViewById(R.id.btn_en).setOnClickListener(this);
}
@Override
public void onClick(View v) {
int id = v.getId();
if (id == R.id.btn_en) {
setLanguage("en");
} else if (id == R.id.btn_th) {
setLanguage("th");
}
}
}
In the example above, when user click on a button. It will change to English or Thai language. That's It! Localization Activity Library example.
It's very easy, right? You barely have to do anything.
Then just build up some String Resouce for English and Thai language.
Complete! Now your application can support multiple language.
I wanted it to be easy to use and does not have to do much coding. So it have only 3 public methods.
void setLanguage(String language)
String getLanguage()
void setDefaultLanguage(String language)
setLanguage Set the language that you needs to change. The string value given will be use for setup Locale class later.
Example
setLanguage("th") // Language : Thailand
setLanguage("th_TH) // Language : Thailand, Country : Thai
setLanguage("en") // Language : English
setLanguage("en_GB") // Language : English, Country : Great Britain
setLanguage("en_US") // Language : English, Country : United States
setLanguage(Locale.KOREA.toString()) // Language : Korean, Country : Korea
setLanguage(Locale.KOREAN.toString()) // Language : Korean
setLanguage(Locale.CANADA_FRENCH.toString()) // Language : French, Country : Canada
So you must determine the correct language for Locale class.
getLanguage Get current language. (Return to string locale)
setDefaultLanguage Set default language if there is no language configuration. Provided that this method must called only once at first activity in your application and called before super.onCreate
@Override
public void onCreate(Bundle savedInstanceState) {
setDefaultLanguage(Locale.JAPAN.toString());
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
...
}
and 2 optional override methods.
void onBeforeLocaleChanged()
void onAfterLocaleChanged()
This override method will be called then activity language was changed. If you need to know when language has change, just override these methods.
Usually change the language code has a problem with activity that already created.
If latest activity can change the language. It does not apply to previous activity.
But no problem for this library when application getback to previous activity. If you extend that activity to LocalizationActivity. It will changed immediately.
When language was changed. An activity wil recreated. So if you have any data object. It should be handle by save/restore instance state for complelely works. (It simple way to supported portrait/landscape orientation)
Therefore you have to override onSaveInstance and onRestoreInstance in to your code, and handle it.
import android.os.Bundle;
import android.view.View;
public class MainActivity extends LocalizationActivity implements View.OnClickListener {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// TODO Initial view and widget here
if (savedInstanceState == null) {
// TODO Activity first created
} else {
// TODO Activity recreated from screen orientation or change language
}
}
@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
// TODO Save instance here
}
@Override
protected void onRestoreInstanceState(Bundle savedInstanceState) {
// TODO Restore instance here
super.onRestoreInstanceState(savedInstanceState);
}
}
It's affect on fragment as well.
Fragment language configuration is depending with activity. If activity language was changed and recreated. It will apply to fragment as well. So you have to handle to Instance State on fragment like an activity.
About Save/Restore Instance State. Read more on The Real Best Practices to Save/Restore Activity's and Fragment's state.
English Version : http://www.akexorcist.com/2015/07/localization-activity-best-way-to-handle-language-en.html
Thai Version : http://www.akexorcist.com/2015/07/localization-activity-best-way-to-handle-language.html
@first087 @AleksanderMielczarek
Copyright 2015 Akexorcist
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this work except in compliance with the License. You may obtain a copy of the License in the LICENSE file, or at:
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.