編輯:關於Android編程
一、需求
有時候應用需要在內部切換語言但又不影響系統的語言,比如是應用現在是中文的,系統語言也是中文的,我把應用的切換成英文顯示後系統語言還是中文的,系統語言切換後也不會被改變,還有就是有些機的系統是被改造精簡過的,比如有些國產機的系統的語言就被精簡剩中文和英文。支付寶、微信、Top Story都有在應用內部設置語言切換這樣的功能。
二、實現效果
先看看實現效果吧。
三、實現
(一)添加多種語言的資源文件夾及文件
我這默認是英語再添加了個俄文(Google翻譯的)和中文。
values/strings.xml
<resources> <string name="app_name">SwitchLanguage</string> <string name="helloworld">Hello World!</string> <string name="language">Eng</string> <string name="english">English</string> <string name="chinese">中文</string> <string name="russian">русский</string> <string name="secondact">Second Activity</string> </resources>
values-ru/strings.xml
<resources> <string name="app_name">Переключение язык</string> <string name="helloworld">привет мир!</string> <string name="language">русский</string> <string name="secondact">второй активность</string> </resources>
values-zh/strings.xml
<resources> <string name="app_name">切換語言</string> <string name="helloworld">你好 世界!</string> <string name="language">中文</string> <string name="secondact">第二屏</string> </resources>
(二)布局文件
activity_main.xml
默認標題欄的文字是切換語言後是不會被改變的,使用Toobar替換掉就可以了。
<?xml version="1.0" encoding="utf-8"?> <LinearLayout android:id="@+id/activity_main" xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context="com.ce.switchlanguage.MainActivity" xmlns:app="http://schemas.android.com/apk/res-auto"> <android.support.design.widget.AppBarLayout android:layout_height="wrap_content" android:layout_width="match_parent" android:theme="@style/AppTheme.AppBarOverlay"> <android.support.v7.widget.Toolbar android:id="@+id/toolbar" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" android:background="?attr/colorPrimary" app:popupTheme="@style/AppTheme.PopupOverlay" app:title="@string/app_name"/> </android.support.design.widget.AppBarLayout> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="@string/helloworld"/> <Button android:id="@+id/change" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:text="@string/language"/> </LinearLayout>
styles.xml
設置語言後需要重啟下activity,啟動會有個效果,使用windowDisablePreview屏蔽掉它。
<resources> <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> <item name="colorPrimary">@color/colorPrimary</item> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <item name="colorAccent">@color/colorAccent</item> <item name="windowActionBar">false</item> <item name="windowNoTitle">true</item> <item name="android:windowDisablePreview">true</item> </style> <style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar"/> <style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Dark"/> </resources>
main_menu.xml
<?xml version="1.0" encoding="utf-8"?> <menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto"> <item android:id="@+id/chinese" android:title="@string/chinese" app:showAsAction="never" /> <item android:id="@+id/english" android:title="@string/english" app:showAsAction="never" /> <item android:id="@+id/russian" android:title="@string/russian" app:showAsAction="never" /> </menu>
(三)LocaleUtils
package com.ce.switchlanguage; import android.content.Context; import android.content.SharedPreferences; import android.content.res.Configuration; import android.os.Build; import android.util.DisplayMetrics; import com.google.gson.Gson; import java.util.Locale; public class LocaleUtils { /** * 中文 */ public static final Locale LOCALE_CHINESE = Locale.CHINESE; /** * 英文 */ public static final Locale LOCALE_ENGLISH = Locale.ENGLISH; /** * 俄文 */ public static final Locale LOCALE_RUSSIAN = new Locale("ru"); /** * 保存SharedPreferences的文件名 */ private static final String LOCALE_FILE = "LOCALE_FILE"; /** * 保存Locale的key */ private static final String LOCALE_KEY = "LOCALE_KEY"; /** * 獲取用戶設置的Locale * @param pContext Context * @return Locale */ public static Locale getUserLocale(Context pContext) { SharedPreferences _SpLocale = pContext.getSharedPreferences(LOCALE_FILE, Context.MODE_PRIVATE); String _LocaleJson = _SpLocale.getString(LOCALE_KEY, ""); return jsonToLocale(_LocaleJson); } /** * 獲取當前的Locale * @param pContext Context * @return Locale */ public static Locale getCurrentLocale(Context pContext) { Locale _Locale; if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { //7.0有多語言設置獲取頂部的語言 _Locale = pContext.getResources().getConfiguration().getLocales().get(0); } else { _Locale = pContext.getResources().getConfiguration().locale; } return _Locale; } /** * 保存用戶設置的Locale * @param pContext Context * @param pUserLocale Locale */ public static void saveUserLocale(Context pContext, Locale pUserLocale) { SharedPreferences _SpLocal=pContext.getSharedPreferences(LOCALE_FILE, Context.MODE_PRIVATE); SharedPreferences.Editor _Edit=_SpLocal.edit(); String _LocaleJson = localeToJson(pUserLocale); _Edit.putString(LOCALE_KEY, _LocaleJson); _Edit.apply(); } /** * Locale轉成json * @param pUserLocale UserLocale * @return json String */ private static String localeToJson(Locale pUserLocale) { Gson _Gson = new Gson(); return _Gson.toJson(pUserLocale); } /** * json轉成Locale * @param pLocaleJson LocaleJson * @return Locale */ private static Locale jsonToLocale(String pLocaleJson) { Gson _Gson = new Gson(); return _Gson.fromJson(pLocaleJson, Locale.class); } /** * 更新Locale * @param pContext Context * @param pNewUserLocale New User Locale */ public static void updateLocale(Context pContext, Locale pNewUserLocale) { if (needUpdateLocale(pContext, pNewUserLocale)) { Configuration _Configuration = pContext.getResources().getConfiguration(); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) { _Configuration.setLocale(pNewUserLocale); } else { _Configuration.locale =pNewUserLocale; } DisplayMetrics _DisplayMetrics = pContext.getResources().getDisplayMetrics(); pContext.getResources().updateConfiguration(_Configuration, _DisplayMetrics); saveUserLocale(pContext, pNewUserLocale); } } /** * 判斷需不需要更新 * @param pContext Context * @param pNewUserLocale New User Locale * @return true / false */ public static boolean needUpdateLocale(Context pContext, Locale pNewUserLocale) { return pNewUserLocale != null && !getCurrentLocale(pContext).equals(pNewUserLocale); } }
Locale工具類,這裡我用SharedPreferences來保存所設置的Locale,Locale是實現了Serializable的。
(四)Activity
package com.ce.switchlanguage; import android.content.Intent; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.support.v7.widget.Toolbar; import android.view.Menu; import android.view.MenuItem; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Toolbar _Toolbar =(Toolbar) findViewById(R.id.toolbar); setSupportActionBar(_Toolbar); } @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.main_menu,menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { int _ItemId=item.getItemId(); switch (_ItemId) { case R.id.chinese: if (LocaleUtils.needUpdateLocale(this, LocaleUtils.LOCALE_CHINESE)) { LocaleUtils.updateLocale(this, LocaleUtils.LOCALE_CHINESE); restartAct(); } break; case R.id.english: if (LocaleUtils.needUpdateLocale(this, LocaleUtils.LOCALE_ENGLISH)) { LocaleUtils.updateLocale(this, LocaleUtils.LOCALE_ENGLISH); restartAct(); } break; case R.id.russian: if (LocaleUtils.needUpdateLocale(this, LocaleUtils.LOCALE_RUSSIAN)) { LocaleUtils.updateLocale(this, LocaleUtils.LOCALE_RUSSIAN); restartAct(); } } return true; } /** * 重啟當前Activity */ private void restartAct() { finish(); Intent _Intent = new Intent(this, MainActivity.class); startActivity(_Intent); //清除Activity退出和進入的動畫 overridePendingTransition(0, 0); } }
這裡只有一個Activity所以切換的時候重啟下當前Activity就好了,棧裡還有其他Activity的自己再處理吧。
(五)Application
package com.ce.switchlanguage; import android.app.Application; import android.content.res.Configuration; import android.os.Build; import java.util.Locale; public class MyApplication extends Application { @Override public void onCreate() { super.onCreate(); Locale _UserLocale=LocaleUtils.getUserLocale(this); LocaleUtils.updateLocale(this, _UserLocale); } @Override public void onConfigurationChanged(Configuration newConfig) { super.onConfigurationChanged(newConfig); Locale _UserLocale=LocaleUtils.getUserLocale(this); //系統語言改變了應用保持之前設置的語言 if (_UserLocale != null) { Locale.setDefault(_UserLocale); Configuration _Configuration = new Configuration(newConfig); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) { _Configuration.setLocale(_UserLocale); } else { _Configuration.locale =_UserLocale; } getResources().updateConfiguration(_Configuration, getResources().getDisplayMetrics()); } } }
在Application onCreate的時候更新下,在系統語言改變的時候也要保持之前設置的語言不變。
源碼地址:Android應用內置語言切換
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持本站。
最近項目裡要做一個簡單的曲線圖來標識數據,開始以為很簡單,android已經有那麼多的開源圖表庫了,什麼achartenginee,hellochart,mpandroi
說起APP應用閃退很多用戶會第一時間想到蘋果設備閃退問題,而出現閃退並非蘋果的"專利",而在安卓蘋果下,近期就有用戶遇到微信手機版出現閃
Android 4.0中添加了一個很有用的特性,那就是overView Screen功能,也就是最近任務預覽功能。這個功能提供了一個列表試圖,方便用戶簡單快捷地了解到最近
Activity:作為四大組件之一,也是與用戶交互最多的組件,因此為了更好的交互效果,了解Activity的生命周期,正確分配每個階段該完成的工作就顯得十分必要,例如: