游戲開發和游戲腳本的那些事


0x00 前言:

自從年底換了公司之后已經有一段時間沒有寫博客了。可能是這段時間工作的更愉快了,所謂“業精於勤,而荒於嬉”吧(此處有表情)。這周終於意識到了這點,看來還是要恢復之前寫博客的狀態。今天就來寫寫游戲引擎和腳本編程的話題吧。

0x01 游戲腳本,用還是不用?

這是一個問題?
游戲開發提供對腳本的支持可謂源遠流長。
f2817bcb0a46f21fe838a1c2f6246b600d33aeda.jpg
2002年的無冬之夜,玩家可以方便的開發Mod。

20090713065321-1538168564.jpg
2005年的黑與白2,按照劇本演繹大電影的感覺。

122433gz64zw4xmrshd9xs.jpg
2011年的老滾5,玩家可以方便的開發自己的Mod,生命力直到6年后的現在依然旺盛。

當然,讓更多人知道游戲腳本的是網絡游戲的興起。

20100530_b6bc8e047ae9176e4f68QBsCEiZELMds.jpg
24b0b051f8198618df2b57d64aed2e738ad4e6a4.png
開發網絡游戲的插件或是外掛,游戲腳本總是要打交道的。

好像大家都在使用腳本開發游戲。

0x02 什么是游戲腳本


使用c/c++開發項目,隨着項目的擴大,源碼的編譯時間也會越來越長。有時修改一些常量就需要重新編譯整個項目。是否感覺到了痛苦?

見招拆招,為了解決這個問題,可以將很多常量放到一個初始化文件中。並且編寫一段代碼去讀取並解析這個文件。這樣,常量就以初始化文件/配置文件的形式獨立出來了。修改常量的值再也不用重新編譯整個項目了!

這就是一個最初級的游戲腳本!而且初始化文件中的文本就是最基本的游戲腳本語言。

但是,僅僅是提供一些常量的讀取和解析似乎還不能夠滿足游戲開發的需求,為了提高游戲開發的效率,節約編譯c/c++項目時泡咖啡的時間,更高級的游戲腳本語言顯然有必要引入。
20121115101523703.jpg
So,更高級的腳本語言增加了腳本和c/c++的交互性,我們不但可以初始化變量,而且可以創建游戲邏輯甚至時游戲對象。

游戲腳本的運行通過虛擬機來進行,我們使用腳本語言的語法編寫的函數可以被虛擬機讀取並運行。換言之,腳本可以通過虛擬機與c/c++進行通信,使得數據可以在兩者之間來回傳遞。

腳本可以是解釋執行的,也可以是編譯執行的。解釋執行的腳本通過解釋器,逐行的讀取、解析和執行。但是,為了節約在運行時的開銷,一些解釋執行的腳本會自動編譯腳本。Lua便是其中的代表。

當然,腳本還可以是編譯執行的。編譯執行的腳本是通過這種腳本語言的編譯器編譯為某種形式的中間語言(IL)的腳本。虛擬機是可以直接執行這種中間語言的。
這種中間語言是平台無關的,換言之,這種中間語言是供虛擬機使用的,而不關心具體的平台。

例如現在很流行的Unity引擎所使用的C#語言。
C_Sharp_wordmark.png
在使用Unity開發游戲的過程中,腳本代碼的編譯只需要分為兩部分就可以了:
第一部分是從C#代碼本身到CIL的編譯(其實之后 CIL還會被編譯成一種位元碼,生成一個 CLI assembly);
第二部分 是運行時從 CIL(其實是 CLI assembly,不過為了直觀理解,此處不必糾結這種細節)到本地 指令的即時編譯(這就引出了為何 Unity 3D官方沒有提供熱更新的原因:在 iOS平台中 Mono 無法使用 JIT 引擎,而是以 Full AOT 模式運行的,所以此處說的即時編譯不包括 iOS 平台)。

0x03為什么要使用腳本?

便捷的初始化文件:

最簡單的應用便是我們可以使用腳本作為初始化文件,這是一個讀入/修改游戲數據快速而方便的方法。

1366785737_283556289.jpg

節約游戲開發的時間,提高效率:

隨着游戲規模的日益龐大,C/C++代碼的編譯時間會越來越久。一些需要經常調試的功能如果每次修改都編譯一遍整個項目,無疑會造成效率的地下。例如ai程序員,常常需要調試查看效果。因此如果都在C/C++中實現,會造成效率的低下。
153_151217092353_1.jpg

降低了編程的門檻,提高了創造性:

不可否認的一點,一些腳本語言比C/C++更高級,這主要體現在語法更加直觀、上手更加容易。因此,一些非程序員也可以使用腳本語言來實現自己的需求。
當然,另一方面來說更容易招到初級程序員。不過,我認為這同時也導致了另外一個問題,即很多程序員因此成為了API搬運工,只知其然而不知其所以然。
276_150719085700_2.jpg

帶來了拓展性,Mod:

使用腳本語言,游戲開發商可以把游戲引擎的功能交給玩家。反過來,通過玩家創造的Mod又為游戲提供了新的生命力。
這方面老滾5是一個經典的例子。11年發售的老滾5由於其拓展性,生命力十分頑強。
0d338744ebf81a4ce2694adbd12a6059252da64d.jpg

0x04 游戲開發中腳本的常見使用場景

對話流

2015111914527186.jpg

使用腳本來管理游戲中的對話是一個最常見的應用。這類腳本常常隨某個特定的事件而觸發。例如場景設計師設計主角在靠近某個NPC時觸發和該NPC的對話。對話內容可以直接由場景設計師來制作。

舞台設計

fda29e9e78f74f000930.jpg
腳本在游戲中常見的一個應用還包括設計舞台。通過腳本來控制游戲場景中的對象和各種事件可以營造出很有沉浸式的游戲場景。
這里游戲腳本就十分類似電影的劇本。

玩法邏輯

1559061_092430.jpg
由於邏輯開發需要經常的調試,如果每次代碼修改都要進行一次冗長的重新編譯,這會造成工作效率和開發人員身體健康的下降。因此使用腳本可以避免這一點。

0x05 后記

在下一篇文章中我們就來聊聊使用Unity游戲引擎開發游戲的過程中和游戲腳本有關的話題吧。
歡迎大家關注我的公眾號慕容的游戲編程:chenjd01
201701312351412651fGTISk.png

最后打個廣告,歡迎支持我的書《Unity 3D腳本編程》~
686199-20160919193306199-2036072132.jpg


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM