English | 中文
Multi-language Text for LayaAir engine.
- Copy /src/co/lujun/laya/component/MultiLangText.jsto{LayaAir IDE directory}/Resources/app/out/vs/layaEditor/renders/custom/
- Copy /src/co/lujun/laya/component/MultiLangText.xmlto{LayaAir IDE directory}/Resources/app/out/vs/layaEditor/renders/custom/
- Copy /src/co/lujun/laya/component/multiLangText.pngto{LayaAir IDE directory}/Resources/app/out/vs/layaEditor/laya/basics/Custom/
- Copy /src/co/lujun/laya/component/multiLangText.pngto{LayaAir IDE directory}/Resources/app/out/vs/layaEditor/laya/icons/components/
- Export /src/co/directory to your project
Init library, there are two ways for init(Sync and Async):
Sync init, when do this, you should preLoad langfile.csv first, when you complete loaded the langFile.csv then call init method. The first parameter preloadLangFile set as true, the second parameter langFilePath set as your langFile.csv path.
Laya.loader.load("res/langFile.csv", Laya.Handler.create(this, function(){
   LangManager.init(true, "res/langFile.csv");
   Laya.stage.addChild(new view.SampleView);
}));Async init, when do this, you can init LangManager in any place, but remember call init method with false(no preloaded langFile.csv). The first parameter preloadLangFile set as false, the second parameter langFilePath set as your langFile.csv path.
Laya.loader.load(["res/atlas/comp.atlas"], Laya.Handler.create(this, function(){
    Laya.stage.addChild(new view.SampleView);
}));
LangManager.init(false, "res/langFile.csv");In UI editor page, open Component tab and click Custom directory, just use MultiLangText like Text.
- Single MultiLangTextusage
let multiLangText: MultiLangText = new MultiLangText();
multiLangText.pos(0, 0);
multiLangText.fontSize = 50;
multiLangText.color = "#ffffff";
multiLangText.multiLang("^BTN_SET", false);
Laya.stage.addChild(multiLangText);- MultiLangTextas- Laya.Text's child usage
let layaText: Laya.Text = new Laya.Text();
let layaTextMultiText: MultiLangText = new MultiLangText();
layaText.pos(300, 0);
layaText.fontSize = 50;
layaText.color = "#ffffff";
layaText.addChild(layaTextMultiText);
layaTextMultiText.multiLang("^BTN_SOUND", true);
Laya.stage.addChild(layaText);- LangManager.getInstance().getValue(langKey: string), with this method, you can get a value with one key
let layaText1: Laya.Text = new Laya.Text();
layaText1.pos(600, 0);
layaText1.fontSize = 50;
layaText1.color = "#ffffff";
layaText1.text = LangManager.getInstance().getValue("^BTN_MUSIC");
Laya.stage.addChild(layaText1);- switchLang(code: LangCode), with this method, you can switch language with LangCode
LangManager.getInstance().switchLang(LangCode.SC);A enum for your translation, located in co.lujun.laya.component.
| enum | value | in .csv file column index(first column index is 0) | description | 
|---|---|---|---|
| EN | 1 | 1 | English | 
| SC | 2 | 2 | 简体中文 | 
| TC | 3 | 3 | 繁體中文 | 
| JP | 4 | 4 | 日本語 | 
Note: When you add new language translation, remember to add one new enum code to LangCode, you also need to add this new enum code into class co.lujun.laya.component.LangManager.mLangCodeArr. In langFile.csv file, add new translation with(Tab).
Enjoy it😄!
- First release.
If you have any questions, contact me: lujun.byte#gmail.com.



