日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

LayaIDE + FGUI + Laya-SimpleFramework-Fairygui框架

發(fā)布時間:2023/12/9 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LayaIDE + FGUI + Laya-SimpleFramework-Fairygui框架 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

LayaIDE + FGUI + Laya-SimpleFramework-Fairygui框架

  • 目錄
    • 一、項目介紹
    • 二、架構(gòu)設(shè)計
    • 三、思維導(dǎo)圖
    • 四、核心邏輯代碼
    • 五、實現(xiàn)效果

目錄

一、項目介紹

近日,在閑余時間把編寫果無數(shù)次的推箱子項目用laya-simpleFramework-FairyGUI框架再實現(xiàn)了一遍。一來想重溫這個編寫過不下五次的推箱子項目邏輯,溫故而知新嘛;二來熟悉aya-simpleFramework-FairyGUI框架,學習一下別人優(yōu)秀的架構(gòu)思路,然后轉(zhuǎn)化為自己的思維。[相關(guān)鏈接]LayaIDE實現(xiàn)推箱子 |C++實現(xiàn)推箱子

二、架構(gòu)設(shè)計

1,LayaIDE采用的是2.9.0_beta版本 LayaIDE下載地址
2,FairyGUI采用的是2020.1.1版本 FGUI官網(wǎng)地址
3,Laya-SimpleFramework-FairyGUI項目 Git地址

三、思維導(dǎo)圖

四、核心邏輯代碼

/*** @desc 游戲核心邏輯*/ export default class GameLogic {private static _instance: GameLogic;public static get Instance(): GameLogic {if (this._instance == null) {this._instance = new GameLogic();}return this._instance;}//是否移動private _moveFlag: boolean = false;public set MoveFlag(value) {this._moveFlag = value;}public get MoveFlag() {return this._moveFlag;}//節(jié)點存儲數(shù)組public nodes: Array<any> = [];//上一步地圖public oldMap = new Array<Array<any>>();//人物位置private posX = 0;private posY = 0;/*** @desc 繪制地圖* @param rootNode 根節(jié)點* @param map 關(guān)卡地圖數(shù)據(jù)* @param width 地圖寬度* @param height 地圖高度*/public draw(rootNode: fgui.GComponent, map: any[][], width: number, height: number) {if (!map || map.length <= 0) return;//刪除所有節(jié)點,初始化rootNode.removeChildren();for (var i = 0; i < width; i++) {for (var j = 0; j < height; j++) {switch (map[i][j]) {//生成空地case 0:// var space = fgui.UIPackage.createObject("MainPack", "0").asImage;// space.setXY(j * 50, i * 50);// space.setSize(50, 50);// rootNode.addChild(space);// //生成的節(jié)點放入數(shù)組處理// this.nodes.push(space);break;//生成墻壁case 1:var wall = fgui.UIPackage.createObject("MainPack", "1").asImage;wall.setXY(j * GameDef.block_width, i * GameDef.block_width);wall.setSize(GameDef.block_width, GameDef.block_width);rootNode.addChild(wall);//生成的節(jié)點放入數(shù)組處理this.nodes.push(wall);break;//生成人物case 2:var man = fgui.UIPackage.createObject("MainPack", "2_" + GameDef.CurActor).asImage;man.setXY(j * GameDef.block_width, i * GameDef.block_width);man.setSize(GameDef.block_width, GameDef.block_width);rootNode.addChild(man);//生成的節(jié)點放入數(shù)組處理this.nodes.push(man);break;//生成箱子case 3:var box = fgui.UIPackage.createObject("MainPack", "3").asImage;box.setXY(j * GameDef.block_width, i * GameDef.block_width);box.setSize(GameDef.block_width, GameDef.block_width);rootNode.addChild(box);//生成的節(jié)點放入數(shù)組處理this.nodes.push(box);break;//生成終點case 4:var end = fgui.UIPackage.createObject("MainPack", "4").asImage;end.setXY(j * GameDef.block_width, i * GameDef.block_width);end.setSize(GameDef.block_width, GameDef.block_width);rootNode.addChild(end);//生成的節(jié)點放入數(shù)組處理this.nodes.push(end);break;//生成終點 + 人case 6:var people_end = fgui.UIPackage.createObject("MainPack", "6").asImage;people_end.setXY(j * GameDef.block_width, i * GameDef.block_width);people_end.setSize(GameDef.block_width, GameDef.block_width);rootNode.addChild(people_end);//生成的節(jié)點放入數(shù)組處理this.nodes.push(people_end);break;//生成終點 + 箱子case 7:var box_end = fgui.UIPackage.createObject("MainPack", "7").asImage;box_end.setXY(j * GameDef.block_width, i * GameDef.block_width);box_end.setSize(GameDef.block_width, GameDef.block_width);rootNode.addChild(box_end);//生成的節(jié)點放入數(shù)組處理this.nodes.push(box_end);break;default:break;}}}}/*** @desc 人物移動* @param dir 移動方向* @param map 關(guān)卡地圖數(shù)據(jù)* @param width 關(guān)卡地圖寬度* @param height 關(guān)卡地圖高度*/public move(dir: Dir, map: any[][], width: number, height: number) {if (!map || map.length <= 0) return;let offsetX = 0, offsetY = 0;//拷貝移動前的地圖數(shù)據(jù)for (var i = 0; i < width; i++) {this.oldMap.push([]);for (var j = 0; j < height; j++) {this.oldMap[i].push([]);this.oldMap[i][j] = map[i][j];}}switch (dir) {//向上移動case Dir.UP:offsetX = -1;offsetY = 0;//更新mapthis.MoveFlag = this.push(map, width, height, offsetX, offsetY);break;//向下移動case Dir.DOWN:offsetX = 1;offsetY = 0;//更新mapthis.MoveFlag = this.push(map, width, height, offsetX, offsetY);break;//向左移動case Dir.LEFT:offsetX = 0;offsetY = -1;//更新mapthis.MoveFlag = this.push(map, width, height, offsetX, offsetY);break;//向右移動case Dir.RIGHT:offsetX = 0;offsetY = 1;//更新mapthis.MoveFlag = this.push(map, width, height, offsetX, offsetY);break;default:break;}}/*** @desc 找到人物坐標* @param map * @param width * @param height */public getPosition(map, width, height) {if (!map || map.length <= 0) return;for (var i = 0; i < width; i++) {for (var j = 0; j < height; j++) {if (2 == map[i][j] || 6 == map[i][j]) {this.posX = i;this.posY = j;}}}}/*** @desc 更新游戲* @param map * @param width * @param height * @param offsetX * @param offsetY */public push(map: any[][], width: number, height: number, offsetX: number, offsetY: number): boolean {if (!map || map.length <= 0) return;this.getPosition(map, width, height);//人物移動前方是空地if (map[this.posX + offsetX][this.posY + offsetY] == 0) {//前一格變?yōu)榭盏?終點map[this.posX][this.posY] -= 2;//下一格變?yōu)槿宋?/span>map[this.posX + offsetX][this.posY + offsetY] = 2;//更新人物位置this.posX += offsetX;this.posY += offsetY;}//人物移動前方是箱子else if (map[this.posX + offsetX][this.posY + offsetY] == 3) {//人物移動前兩格是空地/終點if (0 == map[this.posX + offsetX * 2][this.posY + offsetY * 2]|| 4 == map[this.posX + offsetX * 2][this.posY + offsetY * 2]) {//前一格變?yōu)榭盏?終點map[this.posX][this.posY] -= 2;//下一格變?yōu)槿宋?/span>map[this.posX + offsetX][this.posY + offsetY] = 2;//下兩格變?yōu)橄渥?箱子 + 終點map[this.posX + offsetX * 2][this.posY + offsetY * 2] += 3;//更新人物位置this.posX += offsetX;this.posY += offsetY;}}//人物移動前方是終點else if (map[this.posX + offsetX][this.posY + offsetY] == 4) {//前一格變?yōu)榭盏?終點map[this.posX][this.posY] -= 2;//下一格變?yōu)槿宋?+ 終點map[this.posX + offsetX][this.posY + offsetY] = 6;//更新人物位置this.posX += offsetX;this.posY += offsetY;}//人物移動前方是終點 + 箱子else if (map[this.posX + offsetX][this.posY + offsetY] == 7) {//人物移動前兩格是空地/終點if (0 == map[this.posX + offsetX * 2][this.posY + offsetY * 2]|| 4 == map[this.posX + offsetX * 2][this.posY + offsetY * 2]) {//前一格變?yōu)榭盏?終點map[this.posX][this.posY] -= 2;//下一格變?yōu)槿宋?/span>map[this.posX + offsetX][this.posY + offsetY] = 6;//下兩格變?yōu)橄渥?箱子 + 終點map[this.posX + offsetX * 2][this.posY + offsetY * 2] += 3;//更新人物位置this.posX += offsetX;this.posY += offsetY;}} else {return false;}return true;}/*** @desc 判斷游戲勝利條件* @param map * @param width * @param height */public juide(map: any[][], width: number, height: number) {if (!map || map.length <= 0) return;for (var i = 0; i < width; i++) {for (var j = 0; j < height; j++) {if (map[i][j] == 4 || map[i][j] == 6) {return 0;}}}return 1;}/*** @desc 撤回到前一步* @param map * @param width * @param height */public withdraw(map, width, height) {if ((!map || map.length <= 0) || (this.oldMap || this.oldMap.length <= 0)) return;for (var i = 0; i < width; i++) {for (var j = 0; j < height; j++) {map[i][j] = this.oldMap[i][j];}}//修改移動標志this.MoveFlag = false;}/*** @desc 銷毀* @param map * @param width * @param height */public destroy(map: any[][], width: number, height: number) {if (!map || map.length <= 0) return;let self = this;//銷毀地圖數(shù)據(jù)for (var i = 0; i < width; i++) {for (var j = 0; j < height; j++) {map[i][j] = 0;if (this.oldMap.length > 0) this.oldMap[i][j] = 0;}}//銷毀節(jié)點數(shù)據(jù)this.nodes.forEach(element => {element.dispose();});this.nodes.length = 0;map.length = 0;//銷毀的拷貝地圖數(shù)據(jù)this.oldMap.length = 0;} }

五、實現(xiàn)效果

1,FGUI實現(xiàn)效果

2. web環(huán)境實現(xiàn)效果

總結(jié)

以上是生活随笔為你收集整理的LayaIDE + FGUI + Laya-SimpleFramework-Fairygui框架的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 黄色裸体网站 | 欧美色亚洲色 | 国产精品成人电影在线观看 | 777片理伦片在线观看 | 打屁股疼的撕心裂肺的视频 | a级一a一级在线观看 | 9色91| 日日爱886 | 久久爱影视| 日本免费电影一区二区三区 | 美女福利在线观看 | 最新最全av网站 | 国产另类综合 | 波多野结衣亚洲视频 | 国产极品久久 | 深爱激情站 | 日本成人激情 | 国产精品扒开腿做爽爽爽男男 | 欧美视频精品 | 欧美成人h版在线观看 | 色综合五月婷婷 | 久久久久久人妻一区二区三区 | 奇米网一区二区 | 91日韩欧美 | 天堂网亚洲| 国产视频999 | 一线毛片 | 日本一级黄色录像 | 日韩在线1 | 欧美一区影院 | 无码人妻精品一区二区三 | 亚洲免费激情视频 | 免费人妻精品一区二区三区 | 天天干夜夜嗨 | 国产综合精品在线 | 亚洲精品成人久久 | 精品久久福利 | 亚洲乱子伦 | 波多野吉衣一区 | 一级免费视频 | 成人在线手机视频 | 黄瓜视频在线观看污 | 98国产视频 | 先锋影音av资源站 | 永久av免费在线观看 | 国产在线视频一区二区 | 国产极品久久 | 久久国产免费视频 | 欧美一级影院 | 亚洲成a人片77777精品 | 亚洲激情欧美激情 | 熟妇人妻无乱码中文字幕真矢织江 | 亚洲一区二区福利视频 | 亚洲精久 | 欧美日韩第一页 | 在线你懂的视频 | 国产精品一品二区三区的使用体验 | 国产精品一区二区麻豆 | 欧美久久久久久久久久久久 | 国产一级一片免费播放放a 丁香六月色 | 日韩欧美麻豆 | 成人欧美精品一区二区 | 草逼免费视频 | 久热精品视频在线播放 | 伊人成年综合网 | 蜜臀精品一区二区三区 | 国产精品性 | 刘亦菲毛片 | www四虎影院 | 国产激情精品 | 国产丰满果冻videossex | 99精品视频免费版的特色功能 | 人人草人| 三级理论电影 | 欧美大色| 女人叫床高潮娇喘声录音mp3 | 国产午夜精品无码一区二区 | 久久国产精品精品国产色婷婷 | 欧美xxxx在线| 国产一区自拍视频 | 免费在线观看黄视频 | 99re6在线观看 | 国产女人视频 | 少妇精品亚洲一区二区成人 | 成人午夜视频网站 | av字幕在线 | 伊人久久婷婷 | 欧美整片sss | 人妻在卧室被老板疯狂进入 | 日韩欧美中文字幕一区二区三区 | 精品亚洲乱码一区二区 | 国产精品成久久久久三级 | 色噜噜狠狠一区二区三区 | 波多野结衣电车痴汉 | 蜜桃av噜噜一区二区三区小说 | 日韩福利在线 | 亚洲69av | 538国产精品一区二区免费视频 | 69国产精品视频 |