GameMaker|Script Function 腳本函式|程式基礎

更新於 發佈於 閱讀時間約 9 分鐘

這篇內容,將會講解什麼是腳本函式,以及與腳本函式相關的知識。有了這些概念,各位會更容易理解,要如何設計程式碼。

本篇教學所使用的系統是Windows 10,如果有按鍵相關的說明,會用Windows的系統來解釋。如果你用的是Mac系統,再麻煩自行換成相對應的按鍵。

raw-image


前置知識


在學習本篇內容之前,最好具備以下的前置知識,以免看不懂這篇教學的內容。


Script的簡介


Script是一種資產(Asset),他跟物件(Object)一樣,能夠放置程式碼。

Script有個特色,就是他會在所有的實體生成之前,就先運行過自身的程式碼。

因此,Script就很適合定義函式(Function),或是定義全域變數(Global Variable)。


建立Script的方法,就跟其他的資產一樣。另外,Script也是一個很簡單的資產,裡面除了用來寫程式的頁面,也沒有其他的參數設定了。

Script點開後的樣子

Script點開後的樣子


使用函式(或全域變數)的注意事項


這邊要來解釋,為何Script的這個特色,導致他適合用來放置函式。

首先,如果我們要使用函式,就一定要先定義過函式,我們才能使用。我們之所以可以使用Runtime Function,那是因為GameMaker已經幫我們定義過了。

假設在還沒定義函式之前,就呼叫函式的話,那程式就會跳出「函式尚未定義」的錯誤(全域變數也有類似的狀況)。

基於上述的原因,就導致了Script,很適合拿來定義函式和全域變數。


定義全域變數


定義全域變數的方法,我們已經在變數範圍的教學中提過,差別只是把全域變數,放在Script裡面而已。

如果想要方便管理,可以考慮用一個Script檔案,來放置所有的全域變數。當然,你也可以拆成更多的Script,來進行更細的分類。

用Script來管理全域變數

用Script來管理全域變數


定義函式


從函式的教學中,我們已經知道,函式可以分成「有無回傳數值」和「有無輸入參數」的類型。

這邊將用三個簡單的範例,來解釋要如何在Script上面,定義函式。


🔸有回傳/無參數


當滑鼠的左鍵按下,就會跳出一個視窗,顯示函式的回傳結果。效果就像下面這張GIF:

「有回傳/無參數」的範例

「有回傳/無參數」的範例


接著,我們來展示這個範例的程式碼,如果各位有具備,這篇教學的前置知識,我想應該很快就能理解,要如何定義和使用函式。

以下是Script裡面的程式碼:

function number_plus_ten() {
//此函式,最終會回傳數值100的實數資料
var number = 90 ;
number = number + 10 ;
return number ;
}


接著是Object裡面的Create和Step:

//這段是Create的Event
//將variable_number,設定成函式回傳的資料,也就是100
variable_number = number_plus_ten() ;

//這段是Step的Event
//如果滑鼠的左鍵點下
if (mouse_check_button_pressed(mb_left)) {
//string()可以把variable_number裡的資料,轉換成字串
//顯示variable_number裡面的數值
show_message(string(variable_number)) ;
}


最後,附上範例設定的截圖:


🔸有回傳/有參數


在上個範例中,回傳的數值固定是100(90+10),這不是個很實用的函式,比較實用的函式,應該是能輸入一個參數,然後回傳參數+10的數值回來。

因此接下來,我們要把函式,改良成能輸入參數的樣子:

「有回傳/有參數」的範例

「有回傳/有參數」的範例


以下是Script裡面的程式碼:

function input_plus_ten(instance_input) {
//instance_input表示輸入的參數
//此函式,最終會回傳,輸入參數+10的實數資料
var input = instance_input ;
input = input + 10 ;
return input ;
}


接著是Object裡面的Create和Step:

//這段是Create的Event
//將input_number,設定成40
//將input_number當成參數,放進函式當中
//output_number將會被設定成50
input_number = 40 ;
output_number = input_plus_ten(input_number) ;

//這段是Step的Event
//如果滑鼠的左鍵點下
if (mouse_check_button_pressed(mb_left)) {
//string()可以把variable_number裡的資料,轉換成字串
//顯示output_number裡面的數值
show_message(string(output_number)) ;
}


這是範例設定的截圖:


這種類型的函式,有很多的使用場景,例如:可以用來製作「計算傷害值」的函式,輸入的參數,就是攻擊方的攻擊力,以及受擊方的防禦力。


🔸無回傳/直接運行


無回傳數值的函式,也是一個很常用的程式,這邊我們準備了,一個相關的範例。

這個範例的效果是,當滑鼠的左鍵按下時,隨機改變方塊的座標位置;當滑鼠的右鍵按下時,將方塊的座標設定成(0, 0)。效果就像下面這張GIF:

「無回傳/直接運行」的範例

「無回傳/直接運行」的範例


以下是Script裡面的程式碼:

function random_xy() {
//隨機改變座標的位置,但不會超出畫面
randomise() ;
id.x = irandom_range( 0 , room_width - sprite_get_width(0) ) ;
id.y = irandom_range( 0 , room_height - sprite_get_height(0) ) ;
}

function set_xy( _x , _y ) {
//_x和_y為輸入的參數
//將座標設定成輸入的參數
id.x = _x ;
id.y = _y ;
}


接著是Object裡面的Create和Step:

//這段是Create的Event
//隨機改變block的位置,但不會超出畫面
random_xy() ;

//設定set的座標數值
set_x = 0 ;
set_y = 0 ;

//這段是Step的Event
//如果滑鼠的左鍵點下
if (mouse_check_button_pressed(mb_left)) {
//隨機改變座標的位置,但不會超出畫面
random_xy() ;
}

//如果滑鼠的右鍵點下
if (mouse_check_button_pressed(mb_right)) {
//將座標移動到set的位置
set_xy( set_x , set_y ) ;
}


這是範例設定的截圖:


在這個範例中,我們能發現,在一個Script裡面,能夠同時定義多個函式,如果有需要,也可以同時定義全域變數,就看每個人的使用習慣而定。


什麼是宣告


這邊要來解釋,為何在「有回傳/無參數」的範例中,number要被設定成局部變數。

而在解釋之前,我們要先理解一個新的專有名詞:宣告。


宣告的意思,是告訴電腦,請準備一個空間(通常是記憶體),我們需要存放一些東西。

在一些程式語言中,宣告和賦值的動作,是要分開執行的。但在GameMaker當中,宣告這個動作,幾乎是被忽略掉的,在說明書當中,也沒有特別的說明。

例如:當我們「第一次」對「新的變數」,來進行賦值時,其實就是執行了「宣告」的動作(宣告完順便賦值的意思)。

各位只要記住一點,當我們發動宣告的動作時,電腦就會占用掉一些記憶體。


局部變數的應用


假設範例中的number,改成了實體變數(Instance Variable),那會發生什麼事呢?

function number_plus_ten() {
//改成實體變數的樣子
number = 90 ;
number = number + 10 ;
return number ;
}


首先,函式會把number理解成,這是實體裡面的一個變數,因此第一動作,是先搜索實體裡的程式碼,看看這個變數,有沒有被「宣告」過。

假設有找到,那函式就只會執行「賦值」的動作,也就是把數值重新設定成90,這樣子的流程,並不會額外的佔用記憶體。

但如果沒找到的話呢?那麼函式就會理解成:「需要宣告一個新的變數」,在宣告完之後,程式依然會順利執行,但在記憶體當中,就會出現「垃圾變數」。


「宣告新的變數」並不會改變「實體裡面的程式碼」,換句話說,程式碼裡面不會因此多了一行「number = 90」的宣告。

因此,當我們再次使用函式時,就會「又」產生新的變數,而不是進行賦值的動作。

如果一直重複呼叫這種函式的話,最後就會跳出「記憶體不足」的相關錯誤。


這就是為什麼,我們要在這裡,使用局部變數的原因。

每當使用函式時,函式就會宣告一個新的變數,在用完函式之後,這個變數就會從記憶體中被刪除,這樣就不會產生垃圾變數。




🔔如果內容對你有幫助,可以按個喜歡,這樣就能讓更多人,接觸到這些棒棒的內容🔔


✨祝各位也能開心的做出好遊戲✨

免費、開心、簡單,這是我做教學的理念,我希望透過我的行動,讓人們找回自我學習的快樂,讓那些資源稀少的自學者們,也能朝著自己的夢想來前進。讓我們一起開心的做出遊戲吧!
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
這篇內容,將會講解什麼是函式,以及與函式相關的知識。包括函式的簡介、Runtime Function、自訂函式、Script Function 腳本函式、Method 方法。
這篇內容,將會講解什麼是變數範圍,以及與變數範圍相關的知識。包括變數範圍的簡介、實體變數、全域變數、局部變數、常數。
這篇內容,將會講解什麼是資料型態,以及與資料型態相關的知識。包括資料型態的簡介、實數、布林值、 字串、陣列。
這篇內容,將會用一個簡單的範例,來解釋物件(Object)和實體(Instance)的差別。包括Instance的簡介、ID、物件改變會影響實體。
這篇內容,將會講解什麼是變數,以及與變數相關的知識。包括變數、資料型態、變數賦值、變數的命名規則、變數的作用區域、變數的可重複性、內建變數。
這篇內容,將透過實戰教學,來講解「滑鼠點方塊」的程式碼。包括如何測試遊戲、座標系統、自訂參數和內建參數、if else、and、遊戲的邏輯設計、程式碼解析。
這篇內容,將會講解什麼是函式,以及與函式相關的知識。包括函式的簡介、Runtime Function、自訂函式、Script Function 腳本函式、Method 方法。
這篇內容,將會講解什麼是變數範圍,以及與變數範圍相關的知識。包括變數範圍的簡介、實體變數、全域變數、局部變數、常數。
這篇內容,將會講解什麼是資料型態,以及與資料型態相關的知識。包括資料型態的簡介、實數、布林值、 字串、陣列。
這篇內容,將會用一個簡單的範例,來解釋物件(Object)和實體(Instance)的差別。包括Instance的簡介、ID、物件改變會影響實體。
這篇內容,將會講解什麼是變數,以及與變數相關的知識。包括變數、資料型態、變數賦值、變數的命名規則、變數的作用區域、變數的可重複性、內建變數。
這篇內容,將透過實戰教學,來講解「滑鼠點方塊」的程式碼。包括如何測試遊戲、座標系統、自訂參數和內建參數、if else、and、遊戲的邏輯設計、程式碼解析。
你可能也想看
Google News 追蹤
Thumbnail
現代社會跟以前不同了,人人都有一支手機,只要打開就可以獲得各種資訊。過去想要辦卡或是開戶就要跑一趟銀行,然而如今科技快速發展之下,金融App無聲無息地進到你生活中。但同樣的,每一家銀行都有自己的App時,我們又該如何選擇呢?(本文係由國泰世華銀行邀約) 今天我會用不同角度帶大家看這款國泰世華CUB
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
本章節旨在介紹TypeScript中的函數,包括其基本結構、如何呼叫函數、函數的參數以及函數的返回值等相關概念。通過本章節,讀者可以學習到如何在TypeScript中使用不同的方式來定義函數,如函數聲明、函數表達式、箭頭函數和匿名函數等。
Thumbnail
本章節旨在介紹TypeScript的基本語法,包括一般結構、程式進入點、註解以及變數的定義和賦值。這些知識將幫助讀者瞭解TypeScript的基本架構,並且可以開始使用TypeScript進行開發。
Thumbnail
在本章節中,我們將學習JavaScript的基本語法,包括如何註解代碼和如何聲明變數。瞭解這些基礎知識對於進一步學習和使用JavaScript來編寫代碼是非常重要的。
Thumbnail
JavaScript是一種具有動態型別、弱型別、原型繼承等特性的高級腳本語言,應用範圍廣泛,包括前端開發、後端開發、移動應用等。它被各種公司和開源社區廣泛使用。學習JavaScript需要掌握ECMAScript標準、異步編程、模塊系統等知識。
※ 函式基礎介紹: ※ JavaScript 特殊的函式特性: 函式可以當成值來傳遞 (可以放進變數或放進物件) 函式可以當成函式的參數 callback - 在特定事件中觸發函式 (非同步特性) ※ 函式的基本寫法: ※ 調用 (invoke) 函式: "調用" 意指呼叫或執行
前言: 雖然前面有些定義還沒有完整的解釋,但還是後面再說吧, 誰想一直看理論啊(摔本子)
Thumbnail
完成了Debug.log()的測試,接著還是要跟各位簡單講一下C#的一些規則,之後看程式會(比較)看得懂。 又講到變數? 在Unity中,變數是重要的工具,用來儲存和管理資料。讓開發者能夠靈活調整遊戲的行為和性能,減少代碼的重複性,使得遊戲開發更加高效和簡潔。透過使用變數,開發者可以輕鬆修改資料
※ 認識變數: 變數(variable)是在程式裡面把東西存起來的概念。 基於不讓電腦每次都需要重新運算,把需要花時間運算的東西先存起來,之後再直接拿出來使用,所以我們需要變數。 變數儲存的位置在電腦裡的記憶體。變數就像是一個箱子,記憶體就像是一個倉庫。箱子的名稱就是變數名稱,箱子的內容物就是
對於程序式編程來說,程式是由一系列的指令組成,例如計算數值、印出訊息、修改變數、呼叫子程序、配置變數的記憶體空間等。定義函式是為了讓一些程序可以重複利用,因此稱為子程序,其中參數為子程序中特別的變數,讓我們能夠透過它們控制子程序的行為。函式的回傳值只是一種方便將結果帶回來的方法,但一般只能回傳一個值
Thumbnail
在剛開始寫 JavaScript 可能大多數的人不會特別意識到 JavaScript 的型別系統有什麼特別之處,我是在看完 Youtube 上 CS50 的課程,才理解到在不同的程式語言中,會因為語言的特性而有不同的系統,JavaScript 就是偏向比較特別的那一種。
Thumbnail
現代社會跟以前不同了,人人都有一支手機,只要打開就可以獲得各種資訊。過去想要辦卡或是開戶就要跑一趟銀行,然而如今科技快速發展之下,金融App無聲無息地進到你生活中。但同樣的,每一家銀行都有自己的App時,我們又該如何選擇呢?(本文係由國泰世華銀行邀約) 今天我會用不同角度帶大家看這款國泰世華CUB
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
本章節旨在介紹TypeScript中的函數,包括其基本結構、如何呼叫函數、函數的參數以及函數的返回值等相關概念。通過本章節,讀者可以學習到如何在TypeScript中使用不同的方式來定義函數,如函數聲明、函數表達式、箭頭函數和匿名函數等。
Thumbnail
本章節旨在介紹TypeScript的基本語法,包括一般結構、程式進入點、註解以及變數的定義和賦值。這些知識將幫助讀者瞭解TypeScript的基本架構,並且可以開始使用TypeScript進行開發。
Thumbnail
在本章節中,我們將學習JavaScript的基本語法,包括如何註解代碼和如何聲明變數。瞭解這些基礎知識對於進一步學習和使用JavaScript來編寫代碼是非常重要的。
Thumbnail
JavaScript是一種具有動態型別、弱型別、原型繼承等特性的高級腳本語言,應用範圍廣泛,包括前端開發、後端開發、移動應用等。它被各種公司和開源社區廣泛使用。學習JavaScript需要掌握ECMAScript標準、異步編程、模塊系統等知識。
※ 函式基礎介紹: ※ JavaScript 特殊的函式特性: 函式可以當成值來傳遞 (可以放進變數或放進物件) 函式可以當成函式的參數 callback - 在特定事件中觸發函式 (非同步特性) ※ 函式的基本寫法: ※ 調用 (invoke) 函式: "調用" 意指呼叫或執行
前言: 雖然前面有些定義還沒有完整的解釋,但還是後面再說吧, 誰想一直看理論啊(摔本子)
Thumbnail
完成了Debug.log()的測試,接著還是要跟各位簡單講一下C#的一些規則,之後看程式會(比較)看得懂。 又講到變數? 在Unity中,變數是重要的工具,用來儲存和管理資料。讓開發者能夠靈活調整遊戲的行為和性能,減少代碼的重複性,使得遊戲開發更加高效和簡潔。透過使用變數,開發者可以輕鬆修改資料
※ 認識變數: 變數(variable)是在程式裡面把東西存起來的概念。 基於不讓電腦每次都需要重新運算,把需要花時間運算的東西先存起來,之後再直接拿出來使用,所以我們需要變數。 變數儲存的位置在電腦裡的記憶體。變數就像是一個箱子,記憶體就像是一個倉庫。箱子的名稱就是變數名稱,箱子的內容物就是
對於程序式編程來說,程式是由一系列的指令組成,例如計算數值、印出訊息、修改變數、呼叫子程序、配置變數的記憶體空間等。定義函式是為了讓一些程序可以重複利用,因此稱為子程序,其中參數為子程序中特別的變數,讓我們能夠透過它們控制子程序的行為。函式的回傳值只是一種方便將結果帶回來的方法,但一般只能回傳一個值
Thumbnail
在剛開始寫 JavaScript 可能大多數的人不會特別意識到 JavaScript 的型別系統有什麼特別之處,我是在看完 Youtube 上 CS50 的課程,才理解到在不同的程式語言中,會因為語言的特性而有不同的系統,JavaScript 就是偏向比較特別的那一種。