MLang
是 MultiLanguage 的简写,是一款动态化的多语言框架。
- 动态下发语言包
- 语言包的增加、升级、删除
- 语言包内部任意字符串的增加、升级、删除
- 跟随系统语言
- static 方法 + 单例模式,一处安装,到处使用
- 详尽的中文注释
- 完善的 demo
- 引入
//build.gradle
allprojects {
repositories {
google()
jcenter()
maven { url "https://raw.githubusercontent.com/LinXueyuanStdio/MLang/main" }
}
}
//app/build.gradle
implementation 'com.timecat.component:MLang:1.0.1'
- 在 Application 中初始化,并监听系统语言的更改(如果跟随系统语言的话):
public class MyApplication extends Application {
@SuppressLint("StaticFieldLeak")
public static volatile Context applicationContext;
public static volatile Handler applicationHandler;
@Override
public void onCreate() {
super.onCreate();
applicationContext = this;
applicationHandler = new Handler(applicationContext.getMainLooper());
MyLang.init(applicationContext);
}
@Override
public void onConfigurationChanged(@NonNull Configuration newConfig) {
super.onConfigurationChanged(newConfig);
MyLang.onConfigurationChanged(newConfig);
}
}
其中建议自己新建一个静态类 MyLang 来隔绝 MLang 的 api 变化,提高兼容性和稳定性。
public class MyLang {
public static void init(@NonNull Context applicationContext) {
MLang.action = new AbsLangAction() {...};
try {
MLang.getInstance(applicationContext);
} catch (Exception e) {
e.printStackTrace();
}
}
public static void onConfigurationChanged(@NonNull Configuration newConfig) {
MLang.getInstance(getContext()).onDeviceConfigurationChange(getContext(), newConfig);
}
public static Context getContext() {
return MyApplication.applicationContext;
}
...
}
AbsLangAction
抽象类定义了必要的网络接口,注释和demo给出了详细的说明和实现,只需照抄即可。
使用字符串
//本地和云端都存在的字符串
MyLang.getString("local_string", R.string.local_string)
//本地没有,云端存在的字符串
MyLang.getString("remote_string_only", R.string.fallback_string)
使用语言包
//应用一种语言(这里自动处理了语言包的升级、语言包内部字符串的升级)
MyLang.getInstance().applyLanguage(Context, MLang.LocaleInfo, force=true, init=false);
//删除一种语言
MyLang.getInstance().deleteLanguage(Context, MLang.LocaleInfo);
MLang.LocaleInfo
可以在以下地方找到
//1. 所有云端的语言包
MyLang.getInstance().remoteLanguages
//2. 所有下载到本地、可用的语言包
MyLang.getInstance().languages
//3. 所有非官方的语言包
MyLang.getInstance().unofficialLanguages
//4. 除内置支持的语言外,另外安装的云端的语言包
MyLang.getInstance().otherLanguages