新聞中心
[[90110]]教程說(shuō)明

創(chuàng)新互聯(lián)公司作為成都網(wǎng)站建設(shè)公司,專(zhuān)注網(wǎng)站建設(shè)公司、網(wǎng)站設(shè)計(jì),有關(guān)成都定制網(wǎng)站方案、改版、費(fèi)用等問(wèn)題,行業(yè)涉及VR全景等多個(gè)領(lǐng)域,已為上千家企業(yè)服務(wù),得到了客戶(hù)的尊重與認(rèn)可。
- 技術(shù)工具: Corona SDK
- 執(zhí)行難度: 普通
- 操作時(shí)間: 30 到60分鐘
書(shū)接上文
在本系列文章的前編中,我們了解了平衡球小游戲的基本概念并創(chuàng)建出基礎(chǔ)用戶(hù)界面。在后編中,我們將共同完成基礎(chǔ)物理效果創(chuàng)建、游戲互動(dòng)性編寫(xiě)等工作,并最終制作出能夠給用戶(hù)帶來(lái)樂(lè)趣的應(yīng)用成品。
步驟二十九: 添加物理效果
為游戲中的各個(gè)圖形元素分配物理屬性,要注意靜態(tài)元素是不能移動(dòng)的。另外還要檢查玩家操控的小球與陷阱洞的半徑,這些元素必須聲明使用圓形物理屬性而不能用一般的方形,這樣會(huì)提高物理碰撞效果、提高游戲性。
- -- Add Physics to GFX
- physics.addBody(left, 'static')
- physics.addBody(right, 'static')
- physics.addBody(top, 'static')
- physics.addBody(bottom, 'static')
- physics.addBody(b1, 'static')
- physics.addBody(b2, 'static')
- physics.addBody(b3, 'static')
- physics.addBody(b4, 'static')
- physics.addBody(h1, 'static', {radius = 15})
- physics.addBody(h2, 'static', {radius = 15})
- physics.addBody(h3, 'static', {radius = 15})
- physics.addBody(h4, 'static', {radius = 15})
- physics.addBody(h5, 'static', {radius = 15})
- physics.addBody(player, {radius = 14})
- physics.addBody(goal, 'static', {radius = 15})
步驟三十: 將陷阱小洞設(shè)置為感應(yīng)器
由于作為陷阱的小洞本身不會(huì)產(chǎn)生物理碰撞效果,因此我們只要為其設(shè)置接觸感應(yīng)器即可。
- -- Set Holes as Sensors
- h1.isSensor = true
- h2.isSensor = true
- h3.isSensor = true
- h4.isSensor = true
- h5.isSensor = true
- --gameListeners('add')
- end
步驟三十一: 代碼審查
以下列出的是本教程所提到全部代碼綱要,大家可以從宏觀(guān)角度對(duì)作品進(jìn)行核查,確定所有要素都已經(jīng)包含在程序成品當(dāng)中:
- -- Teeter like Game
- -- Developed by Carlos Yanez
- -- Hide Status Bar
- display.setStatusBar(display.HiddenStatusBar)
- -- Physics
- local physics = require('physics')
- physics.start()
- physics.setGravity(0, 0)
- -- Graphics
- -- [Background]
- local bg = display.newImage('bg.png')
- -- [Title View]
- local titleBg
- local playBtn
- local creditsBtn
- local titleView
- -- [Credits]
- local creditsView
- -- [Player]
- local player
- -- [Bars Table]
- local bars = {}
- -- [Holes Table]
- local holes = {}
- -- [Goal]
- local goal
- -- Sounds
- local bell = audio.loadSound('bell.caf')
- local buzz = audio.loadSound('buzz.caf')
- -- Functions
- local Main = {}
- local startButtonListeners = {}
- local showCredits = {}
- local hideCredits = {}
- local showGameView = {}
- local gameListeners = {}
- local movePlayer = {}
- local onCollision = {}
- local alert = {}
- local dragPaddle = {}
- -- Main Function
- function Main()
- titleBg = display.newImage('titleBg.png')
- playBtn = display.newImage('playBtn.png', display.contentCenterX - 35.5, display.contentCenterY + 10)
- creditsBtn = display.newImage('creditsBtn.png', display.contentCenterX - 50.5, display.contentCenterY + 65)
- titleView = display.newGroup(titleBg, playBtn, creditsBtn)
- startButtonListeners('add')
- end
- function startButtonListeners(action)
- if(action == 'add') then
- playBtn:addEventListener('tap', showGameView)
- creditsBtn:addEventListener('tap', showCredits)
- else
- playBtn:removeEventListener('tap', showGameView)
- creditsBtn:removeEventListener('tap', showCredits)
- end
- end
- function showCredits:tap(e)
- playBtn.isVisible = false
- creditsBtn.isVisible = false
- creditsView = display.newImage('credits.png', 0, display.contentHeight+40)
- transition.to(creditsView, {time = 300, y = display.contentHeight-20, onComplete = function() creditsView:addEventListener('tap', hideCredits) end})
- end
- function hideCredits:tap(e)
- playBtn.isVisible = true
- creditsBtn.isVisible = true
- transition.to(creditsView, {time = 300, y = display.contentHeight+creditsView.height, onComplete = function() creditsView:removeEventListener('tap', hideCredits) display.remove(creditsView) creditsView = nil end})
- end
- function showGameView:tap(e)
- transition.to(titleView, {time = 300, x = -titleView.height, onComplete = function() startButtonListeners('rmv') display.remove(titleView) titleView = nil end})
- -- [Add GFX]
- -- Goal
- goal = display.newImage('goal.png')
- goal.x = 439
- goal.y = 31
- goal.name = 'g'
- -- Walls
- local left = display.newLine(-1, 0, -1, display.contentHeight)
- local right = display.newLine(display.contentWidth+1, 0, display.contentWidth+1, display.contentHeight)
- local top = display.newLine(0, -3, display.contentWidth, -3)
- local bottom = display.newLine(0, display.contentHeight, display.contentWidth, display.contentHeight)
- -- Bars
- local b1 = display.newImage('bar.png', 92, 67)
- local b2 = display.newImage('bar.png', 192, -2)
- local b3 = display.newImage('bar.png', 287, 67)
- local b4 = display.newImage('bar.png', 387, -2)
- -- Holes
- local h1 = display.newImage('hole.png', 62, 76)
- local h2 = display.newImage('hole.png', 124, 284)
- local h3 = display.newImage('hole.png', 223, 224)
- local h4 = display.newImage('hole.png', 356, 114)
- local h5 = display.newImage('hole.png', 380, 256)
- h1.name = 'h'
- h2.name = 'h'
- h3.name = 'h'
- h4.name = 'h'
- h5.name = 'h'
- -- Player
- player = display.newImage('player.png')
- player.x = 49
- player.y = 288
- player:setReferencePoint(display.CenterReferencePoint)
- -- Add Physics to GFX
- physics.addBody(left, 'static')
- physics.addBody(right, 'static')
- physics.addBody(top, 'static')
- physics.addBody(bottom, 'static')
- physics.addBody(b1, 'static')
- physics.addBody(b2, 'static')
- physics.addBody(b3, 'static')
- physics.addBody(b4, 'static')
- physics.addBody(h1, 'static', {radius = 15})
- physics.addBody(h2, 'static', {radius = 15})
- physics.addBody(h3, 'static', {radius = 15})
- physics.addBody(h4, 'static', {radius = 15})
- physics.addBody(h5, 'static', {radius = 15})
- physics.addBody(player, {radius = 14})
- physics.addBody(goal, 'static', {radius = 15})
- -- Set Holes as Sensors
- h1.isSensor = true
- h2.isSensor = true
- h3.isSensor = true
- h4.isSensor = true
- h5.isSensor = true
- gameListeners('add')
- end
步驟三十二: 游戲監(jiān)聽(tīng)器
下列代碼的作用是為應(yīng)用程序添加重力加速及物理碰撞監(jiān)聽(tīng)器。代碼還能通過(guò)遞交參數(shù)來(lái)移除這些效果。
- function gameListeners(action)
- if(action == 'add') then
- Runtime:addEventListener('accelerometer', movePlayer)
- player:addEventListener('collision', onCollision)
- player:addEventListener('touch', dragPaddle)
- else
- Runtime:removeEventListener('accelerometer', movePlayer)
- player:removeEventListener('collision', onCollision)
- player:removeEventListener('touch', dragPaddle)
- end
- end
步驟三十三: 移動(dòng)小球
以下函數(shù)用來(lái)捕捉物理加速值,并根據(jù)結(jié)果給小球的X及Y屬性賦值。
- function movePlayer:accelerometer(e)
- player.x = player.x + (e.yGravity*-15)
- player.y = player.y + (e.xGravity*-15)
- end
步驟三十四: 物理碰撞
當(dāng)小球與其它對(duì)象發(fā)生碰撞時(shí),其名稱(chēng)會(huì)與觸碰對(duì)象相比照。根據(jù)對(duì)象類(lèi)型的不同(陷阱小洞及目的地),游戲會(huì)給出不同的提示信息。
- function onCollision(e)
- if(e.other.name == 'h') then
- alert()
- elseif(e.other.name == 'g') then
- alert('win')
- end
- end
步驟三十五: 提示信息
提示信息被觸發(fā)時(shí),游戲中的所有監(jiān)聽(tīng)器都會(huì)被移除,并在播放音效的同時(shí)顯示正確的文本內(nèi)容。
- function alert(action)
- local alert
- gameListeners('rmv')
- if(action == 'win') then
- alert = display.newImage('complete.png')
- alert.x = display.contentCenterX
- alert.y = display.contentCenterY
- transition.from(alert, {time = 300, xScale = 0.3, yScale = 0.3})
- audio.play(bell)
- else
- alert = display.newImage('gameOver.png')
- alert.x = display.contentCenterX
- alert.y = display.contentCenterY
- transition.from(alert, {time = 300, xScale = 0.3, yScale = 0.3})
- audio.play(buzz)
- end
- end
步驟三十六: 模擬移動(dòng)
這一步純屬建議,大家可以將下列代表添加進(jìn)來(lái),借以在模擬環(huán)境下拖動(dòng)小球,觀(guān)察移動(dòng)方式是否與預(yù)期相符。
- function dragPaddle(e)
- if(e.phase == 'began') then
- lastY = e.y - player.y
- lastX = e.x - player.x
- elseif(e.phase == 'moved') then
- player.y = e.y - lastY
- player.x = e.x- lastX
- end
- end
步驟三十七: 調(diào)用Main函數(shù)
為了在應(yīng)用啟動(dòng)時(shí)進(jìn)行初始化,我們需要調(diào)用Main函數(shù)。上述代碼編寫(xiě)完成之后,我們只需編輯以下內(nèi)容即可實(shí)現(xiàn)初始化需求:
- Main()
步驟三十八: 載入界面
[[90111]]
當(dāng)我們啟動(dòng)指南針應(yīng)用時(shí),iOS系統(tǒng)會(huì)逐項(xiàng)載入基本數(shù)據(jù),這時(shí)Default.png文件將作為背景圖案顯示在主屏幕當(dāng)中。將這張圖片保存到我們的項(xiàng)目資源文件夾中,這樣它就會(huì)被自動(dòng)添加到Corona的編譯器中。
步驟三十九: 圖標(biāo)
[[90110]]
現(xiàn)在大家的做圖功力就該派上用場(chǎng)了,快為自己的應(yīng)用打造一款美觀(guān)又令人印象深刻的圖標(biāo)吧。在非視網(wǎng)膜屏的iPhone設(shè)備上,圖標(biāo)文件的尺寸應(yīng)為57x57像素,而視網(wǎng)膜屏則需要114x114像素,另外我們還需要為iTunes軟件商店打造一個(gè)512x512的大版圖形。我建議大家先以512x512像素為基準(zhǔn)設(shè)計(jì),然后再縮小成其它兩種尺寸。
大家沒(méi)必要在圖標(biāo)制作方面過(guò)分投入精力,制作圓角或者添加半透明特效完全是種花蛇添足——因?yàn)閕Tunes與iPhone會(huì)自動(dòng)為你實(shí)現(xiàn)這些效果。
步驟四十: 在模擬環(huán)境下進(jìn)行測(cè)試
是時(shí)候進(jìn)行最終測(cè)試了。打開(kāi)Corona模擬器,選擇我們的項(xiàng)目文件夾并點(diǎn)擊“打開(kāi)”。如果一切都依照預(yù)期效果順利運(yùn)行,那么我們就可以著手做***一項(xiàng)工作了。
步驟四十一: 創(chuàng)建
在Corona模擬器中,點(diǎn)選文件選項(xiàng)下的創(chuàng)建項(xiàng)并選擇目標(biāo)設(shè)備平臺(tái)。在對(duì)話(huà)框中輸入項(xiàng)目數(shù)據(jù)并點(diǎn)擊創(chuàng)建按鈕。等上幾秒,我們的應(yīng)用作品就大功告成啦!接下來(lái)大家可以在設(shè)備上進(jìn)行實(shí)機(jī)測(cè)試,或者直接將應(yīng)用發(fā)布到軟件商店中。
總結(jié)
后期測(cè)試總是越多越好,當(dāng)我們對(duì)自己的應(yīng)用作品詳加打磨后,發(fā)行用戶(hù)版吧——這也許會(huì)成為輝煌成功的***步!
希望這篇指南文章能夠幫助大家在移動(dòng)開(kāi)發(fā)的道路上越走越好,感謝朋友們的支持!
分享標(biāo)題:Corona SDK游戲開(kāi)發(fā)實(shí)例(二):物理效果與互動(dòng)操作
鏈接URL:http://www.dlmjj.cn/article/dpohhhs.html


咨詢(xún)
建站咨詢(xún)
