LayaAir之UI文件模式-创新互联
LayaAir版本 : Laya2.0.0bate4 .
公司主营业务:做网站、成都做网站、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出泗洪免费做网站回馈大家。一 : 前言
之所以选用文件模式.本人觉得有这么几个好处:
①,在制作小游戏时,可大限度的减少包体大小(这个是显而易见的 , 尤其是UI比较多/大的情况之下)
②,可以使用Zip等打包生成的文件,从而相对减少网络请求次数.
③,可以对UI类再次的封装(继承Scane).从而大限度得提升本系统的扩展性,适应性的.
本篇只讲解文件模式的实现方式.
二 : 使用文件模式
①,新建UI , 文件类型选择"文件模式" , 如下:
制作完UI,记得导出哦,亲.
②,编写UI代码
export default class Demo extends Laya.Dialog{
private bbb : Laya.Button= null;
public constructor(){
super();
this.once( Laya.Event.ADDED , this , this.add );
this.createView( Laya.Loader.getRes("test/Demo.json") );
}
private add() : void{
this.bbb.on( Laya.Event.CLICK , this , () : void => {
console.log("按钮被单击了");
this.close();
} );
}
}
补充
注意 :
Ⅰ : Laya.Loader.getRes , 如果是远程资源(小游戏一般会将Ui文件扔到远程服务器的) , 前面要加域名信息 , 如 : this.createView( Laya.Loader.getRes("https://xxx.com/gameres/test/Demo.json") );
Ⅱ : Atlas取里面的cell时不需要加域名 , 其他都是需要的.
③,显示UI
注意 - 先加载必要的文件如
Ⅰ, UI中用到的资源(图片资源 , 图集资源)
Ⅱ , UI的皮肤文件 , 如 : Demo.json (bin目录下面)
Ⅲ , 其他预加载的资源
代码 :
Laya.loader.load(
[
{ url : "res/atlas/comp.atlas" , type : Laya.Loader.ATLAS },
{ url : "test/Demo.json" , type : Laya.Loader.JSON }
],
Laya.Handler.create( this, () : void => {
let $ing : Laya.Image = new Laya.Image();
$ing.skin = "comp/textinput.png";
$ing.width = GameConfig.width;
$ing.height = GameConfig.height;
Laya.stage.addChild( $ing );
let $lab : Laya.Label = new Laya.Label();
$lab.text = "请单击!!! , 弹出Dialog";
$lab.fontSize = 50;
$lab.y = 500;
Laya.stage.addChild( $lab );
$ing.on( Laya.Event.CLICK , this , () : void => {
let $demo : Demo = new Demo();
$demo.popup( false );
} );
} ),
null
);
不用再向分离模式用的Laya.Scene.open("test/Demo.scene") 这样坑爹的写法了.
效果:
另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
网站栏目:LayaAir之UI文件模式-创新互联
网站网址:http://azwzsj.com/article/digdee.html