佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > HTML5+lufylegend實(shí)現(xiàn)游戲中的卷軸

HTML5+lufylegend實(shí)現(xiàn)游戲中的卷軸

熱門標(biāo)簽:檢查注冊(cè)表項(xiàng) 網(wǎng)站建設(shè) 硅谷的囚徒呼叫中心 智能手機(jī) 使用U盤裝系統(tǒng) 阿里云 美圖手機(jī) 百度競(jìng)價(jià)點(diǎn)擊價(jià)格的計(jì)算公式
lufylegend是一個(gè)HTML5開源引擎,它實(shí)現(xiàn)了利用仿ActionScript3.0的語(yǔ)法進(jìn)行HTML5的開發(fā), 包含了LSprite,LBitmapData,LBitmap,LLoader,LURLLoader,LTextField,LEvent等多個(gè)AS開發(fā)人員熟悉的類, 支持Google Chrome,F(xiàn)irefox,Opera,IE9,IOS,Android等多種熱門環(huán)境。 利用lufylegend可以輕松的使用面向?qū)ο缶幊?,并且可以配合Box2dWeb制作物理游戲, 另外它還內(nèi)置了LTweenLite緩動(dòng)類等非常實(shí)用的功能, 現(xiàn)在開始使用它吧,它可以讓你更快的進(jìn)入HTML5的世界!
什么是卷軸
玩過(guò)RPG或者橫版格斗的同學(xué)應(yīng)該知道,人物走到屏幕中央后,由于地圖過(guò)大,地圖會(huì)進(jìn)行移動(dòng),人物則相對(duì)靜止不動(dòng)。這個(gè)就是傳說(shuō)中的卷軸。例如下圖是我的游戲“三國(guó)戰(zhàn)線”里的卷軸:


有了以上的簡(jiǎn)介,大家應(yīng)該明白了什么是卷軸。說(shuō)白了就是鏡頭跟隨主角的效果。接下來(lái),我們就利用lufylegend.js游戲引擎來(lái)實(shí)現(xiàn)這個(gè)效果。
原理介紹
其實(shí)實(shí)現(xiàn)這個(gè)效果的關(guān)鍵在于如何使人物靜止,何時(shí)移動(dòng)地圖,以及如何移動(dòng)地圖。在探究這個(gè)兩個(gè)問(wèn)題之前,我們先創(chuàng)建一個(gè)結(jié)構(gòu)良好的舞臺(tái)層(及一個(gè)LSprite對(duì)象),以便以后的操作。舞臺(tái)結(jié)構(gòu)如下:
+- 舞臺(tái)層
|
+- 地圖層
|
+- 人物層
可見舞臺(tái)層就是地圖層和人物層的父元素,并且人物層在地圖層上方,畢竟人物是站在地圖上的。我們知道,子對(duì)象的坐標(biāo)是相對(duì)于父對(duì)象的,所以移動(dòng)父對(duì)象,子對(duì)象會(huì)跟著移動(dòng)。這點(diǎn)要先弄明白。
如何使人物靜止呢?何時(shí)移動(dòng)地圖呢?如何移動(dòng)地圖呢?也許你會(huì)想,首先用if(xxx){...}來(lái)判斷人物的坐標(biāo)是否達(dá)到屏幕中央,如果是,則移動(dòng)地圖對(duì)象,如果不是則移動(dòng)人物對(duì)象。這么做的話就麻煩了。其實(shí)有更簡(jiǎn)單的方法:
卷軸/不卷軸時(shí),我們的人物都是在移動(dòng),但是如果人物達(dá)到屏幕中央時(shí),要開始卷軸了,我們的舞臺(tái)層就進(jìn)行與人物速度方向相反、大小相同的移動(dòng),那么人物的相對(duì)于canvas畫布的位移就抵消了,看上去就是靜止的,而地圖就跟著父類向反方向移動(dòng)。這個(gè)類似于拍古裝電影,拍兩個(gè)人一邊騎馬一邊談話。如果人和馬在前進(jìn),攝像機(jī)以相同的速度跟拍,那么得到的畫面就是人物并沒(méi)有移動(dòng),而人物背后風(fēng)景是在移動(dòng)的。
接下來(lái)看實(shí)現(xiàn)代碼。
實(shí)現(xiàn)代碼
以下是含有詳細(xì)注釋的代碼:
XML/HTML Code復(fù)制內(nèi)容到剪貼板
  1. LInit(30, 'mydemo', 700, 480, main);    
  2. // 移動(dòng)方向,null代表沒(méi)移動(dòng)    
  3. var direction = null;    
  4. // 小鳥,舞臺(tái)層,背景對(duì)象    
  5. var bird, stageLayer, bg;    
  6. // 每次移動(dòng)的長(zhǎng)度    
  7. var step = 5;    
  8. function main () {    
  9. // 資源列表    
  10. var loadList = [    
  11. {name : 'bird', path : './bird.png'},    
  12. {name : 'bg', path : './bg.jpg'}    
  13. ];    
  14. // 加載資源    
  15. LLoadManage.load(loadList, null, demoInit);    
  16. }    
  17. function demoInit (result) {    
  18. // 初始化舞臺(tái)層    
  19. stageLayer = new LSprite();    
  20. addChild(stageLayer);    
  21. // 加入背景    
  22. bg = new LBitmap(new LBitmapData(result['bg']));    
  23. bg.y = -100;    
  24. stageLayer.addChild(bg);    
  25. // 加入小鳥    
  26. bird = new LBitmap(new LBitmapData(result['bird']));    
  27. bird.x = 100;    
  28. bird.y = 150;    
  29. stageLayer.addChild(bird);    
  30. // 添加鼠標(biāo)按下事件    
  31. stageLayer.addEventListener(LMouseEvent.MOUSE_DOWN, onDown);    
  32. // 添加鼠標(biāo)彈起事件    
  33. stageLayer.addEventListener(LMouseEvent.MOUSE_UP, onUp);    
  34. // 添加時(shí)間軸事件    
  35. stageLayer.addEventListener(LEvent.ENTER_FRAME, onFrame);    
  36. }    
  37. function onDown (e) {    
  38. /** 根據(jù)點(diǎn)擊位置設(shè)置移動(dòng)方向 */    
  39. if (e.offsetX > LGlobal.width / 2) {    
  40. direction = 'right';    
  41. } else {    
  42. direction = 'left';    
  43. }    
  44. }    
  45. function onUp () {    
  46. // 設(shè)置方向?yàn)闊o(wú)方向,代表不移動(dòng)    
  47. direction = null;    
  48. }    
  49. function onFrame () {    
  50. var _step, minX, maxX;    
  51. /** 移動(dòng)小鳥 */    
  52. if (direction == 'right') {    
  53. _step = step;    
  54. } else if (direction == 'left') {    
  55. _step = -step;    
  56. } else {    
  57. return;    
  58. }    
  59. bird.x += _step;    
  60. /** 控制小鳥移動(dòng)范圍 */    
  61. minX = 0,    
  62. maxX = bg.getWidth() - bird.getWidth();    
  63. if (bird.x < minX) {    
  64. bird.x = minX;    
  65. }else if (bird.x > maxX) {    
  66. bird.x = maxX;    
  67. }    
  68. /** 移動(dòng)舞臺(tái) */    
  69. stageLayer.x = LGlobal.width / 2 - bird.x;    
  70. /** 控制舞臺(tái)移動(dòng)范圍 */    
  71. minX = LGlobal.width - stageLayer.getWidth(),    
  72. maxX = 0;    
  73. if (stageLayer.x < minX) {    
  74. stageLayer.x = minX;    
  75. }else if (stageLayer.x > maxX) {    
  76. stageLayer.x = maxX;    
  77. }    
  78. }    
運(yùn)行結(jié)果:


大家可以到這里查看在線演示。點(diǎn)擊屏幕左半邊控制小鳥向左移動(dòng),點(diǎn)擊右半邊屏幕,控制小鳥向右移動(dòng)。小鳥到達(dá)屏幕中央后,開始卷軸。

標(biāo)簽:煙臺(tái) 黃山 湘潭 山南 通遼 賀州 湖北 懷化

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5+lufylegend實(shí)現(xiàn)游戲中的卷軸》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    莲花县| 晋宁县| 星子县| 清丰县| 永德县| 天水市| 葫芦岛市| 启东市| 宁明县| 衡南县| 静海县| 咸丰县| 乐至县| 海盐县| 利川市| 南漳县| 蕲春县| 宁化县| 江油市| 芜湖市| 高青县| 甘谷县| 南投市| 金寨县| 沭阳县| 大厂| 白玉县| 宣威市| 黎平县| 德格县| 利辛县| 沙坪坝区| 广宗县| 南漳县| 灵丘县| 宜丰县| 清丰县| 巩义市| 嘉定区| 长寿区| 东乌珠穆沁旗|