Skip to main content

[Lua] 一分鐘搞懂 Corona SDK 中 「.」與「:」執行函式時的差別



之前有網友在 台灣可樂娜跨平台基地 - Corona SDK 上詢問 Corona SDK 中 table listener 與 function listener 差別。

其實 :addEventListener 時並沒有強制一定需要使用 table listener,因為它在執行 listener 函式時,對於 table 物件會使用 tableObj:listenerFunc ,而單純的 function 是正常執行 listenerFunc() ,差別是 function listener 不會因為「:」語法糖而將 table 本身帶入。
其實只要看下面範例就可以馬上清楚知道其中的差別:

local rect1 = display.newRect( 20, 20, 50, 50 )
rect1.name = "Rect1"

local rect2 = display.newRect( 100, 20, 50, 50 )
rect2.name = "Rect2"

local function onTouch1(self, event)
print(self.name)
end

local function onTouch2(event)
local self = event.target
print(self.name)
end

rect1.touch = onTouch1
rect1:addEventListener("touch", rect1 )

rect2:addEventListener("touch", onTouch2 )


以上沒有限定一定要如何宣告,端看你需要函式幫你做什麼而定。

同理下面兩個函式宣告是同等的:

function rect1:touch(event)
print(self.name)
end

rect1.touch = function(self, event)
print(self.name)
end
rect1:addEventListener("touch", rect1 )


可以看出「.」與「:」的差別了嗎?

最後一個範例:


local object = {name='Corona'}

-- 這是一般 table function 宣告方法
function object:sayHaha()
print(self.name..":Haha...")
end

object:sayHaha()
-- output: Corona:Haha...

object.sayHelo = function(self)
print(self.name..":Hello.")
end

object:sayHelo()
-- output: Corona:Hello.

-- 而不是
object.sayHelo()
-- output error self is nil

object.say = function(string)
print(string)
end

object.say("Lua is fun.")
-- output: Lua is fun.

-- 而不是
object:say("Lua is fun.")
-- 因為:的關係第一個屬性會被帶入 object 所以 output: table: 0x10d01c490

Comments

Popular posts from this blog

[Unity] erinylin.lazylib - Cookie for PlayerPrefs

有鑑於 PlayerPrefs 測試與版本更新問題,將大家都愛用的 PreviewLabs.PlayerPrefs 打包起來,製作重點還是以懶人為主,基本上 PlayerPrefs 資料更新與數量並不可能會有強烈衝擊效能的狀況產生,所以為了方便開發,就弄了一個視覺化工具,方便除錯用。

雖然 PreviewLabs.PlayerPrefs 作者都宣告放棄他們的版權,不過為了尊重程式,僅僅加入了兩個公用函式,其他並無更改。

內有:
Cookie ManagerCookie 用 DataObject 混合編輯 ScriptableObject執行階段除錯視窗工具當然還是有懶人常數檔案輸出資料版本控制,方便更新版後儲存資料更新功能其實很多,有興趣的請自行到 Github 下載並參考範例吧!

[AIR] JoSiResize - Mobile 開發小工具

JoSiResizev0.6.0,Adobe AIR 3 runtime之前開發 tool app 的時候並沒有很深刻的體認到圖片素材的 resize 是一個很麻煩的事情...畢竟圖片使用量並不大,等到開發遊戲類的 app 才發現光處理不同螢幕尺寸的圖片素材是一個相當折磨人的工作。
因此 JoSiResize app 誕生了~~~原理是採用最小 scale 長寬比例不變的方式進行放大縮小。使用方法非常簡單,設定好變更的尺寸,接下來,將需要處理的圖片檔案全選直接拖曳到視窗內,畫面即會跳出預備儲存的檔案夾選擇畫面,確認後即開始轉檔。

[Mac app] 開啟 Mac OSX 中自帶的 Color Picker 並加上 HexColorPicker 功能

參考出處:Mac — Adding Hex Color Picker to Color Picker

Mac app store 上有很多 Color Picker app,差不多 98% 都是需要付費,而這個小工具恰恰是開發中不可缺少一個東西。其實 Mac OSX 中就有自帶一個 ColorPicker,秉持著 DIY 的精神,用幾個小步驟就可以組合出顯示 Hex 色碼的 ColorPicker.app。

Mac 系統需求:10.4 and up