微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

Sign發表於2018-09-20

在一些時間以前,比如2012年之前,做web遊戲的人還不是很多(就是用javascript寫遊戲的人)。

當時也沒想那麼多,就是為了製作一個「不需要下載,點開就能玩的遊戲」,所以就投入到web遊戲製作的大海中。

但那時很多人都說,「你這些東西看著蠻好玩的,但感覺沒什麼用啊」。

其實我不是很理解「沒什麼用」是什麼概念,「好玩」難道不夠嗎?

然後時間來到2018年,微信推出了小遊戲。於是web遊戲製作技術忽然從一個「沒什麼用的技術」一躍變成了時下最潮流的技術。

——————————————分割線————————————————

其實我只喜歡一個title,遊戲製作人。但因為一直沒有一款具有代表性的遊戲,所以我一直不知道怎麼做自我介紹。

真希望哪天可以自豪的介紹:我是 xx 遊戲的製作人。

我所在團隊是騰訊互娛的TGideas,會議上稍微吹了會,感興趣的同學自行搜尋。


微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

——————————————分割線————————————————

接下來是正題:

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

主題分為4個部分(忽略旁邊那個表情包):

  1. 基礎概念

  2. 架構設計

  3. 部分演算法

  4. 微信API

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

遊戲的驅動由開發編寫遊戲邏輯,然後在渲染器中實時渲染到畫布上。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲和傳統web遊戲(canvas類)最大的區別在於API。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

小遊戲的表現既可以像跳一跳那樣休閒,也可以像街機的格鬥遊戲一樣熱血,不要被想象力所限制,認為「小遊戲就應該有小遊戲的樣子」。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

當然,一般會有「小遊戲就該是什麼樣」的想法的人,多少是對遊戲有所瞭解的人才會發出的感慨,因為我們需要戴上名為「現實」的技術枷鎖。

這種想法並沒有錯,反而比那些沒有套上枷鎖,而要求他人根據手機殼的顏色改變手機背景顏色的人要好很多。

但是,在戴上了技術枷鎖以後還能保持天馬行空的想象力,那才是最難能可貴的。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲的檔案結構

game.js以及game.json分別是小遊戲的入口檔案及配置檔案。

res是遊戲資源,也是遊戲佔用體積最大的地方。

adapter是利用微信API模擬瀏覽器API的庫。

而src部分就是本次分享的重點內容。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

我個人製作的小遊戲目前畫風都比較奔放,所以分享時借用團隊製作的小遊戲來介紹了。

遊戲結構分為3個大的模組:

Base 模組管理指令碼,用來組織起整個遊戲的部分。負責遊戲的開始,暫停,決定遊戲該呼叫哪個場景。

Scene 場景模組,類似於不同的關卡,每個關卡里需要載入什麼樣的角色,什麼樣的敵人,播放什麼樣的音樂都由場景模組決定。

Role 角色模組,遊戲邏輯中最重要的一個部分。不論是主角還是敵人,甚至場景裡的一個寶箱,一顆子彈,都屬於角色。

剩下的模組都是對不同遊戲進行補完,因為一個格鬥遊戲和一個休閒遊戲所需要的模組差別是非常大的。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

角色模組可以大致分為4個部分:屬性、動畫、指令、行為。

屬性:我們可以把一個object叫做實體,這個實體裡的屬性就是角色的屬性,比如座標,hp,speed等等。

動畫:角色的動畫一般有屬性動畫,序列幀動畫,骨骼動畫這幾種,這些動畫中部分還有2d和3d的區別。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

動畫這一部分屬於「跨領域」作業,因為要把一些「感性」的影像轉化成「理性」的程式碼。這部分的介紹以後會陸續放出。

指令:指令是玩家輸入手段的一種封裝。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

例如,「水果忍者」的滑動切水果的指令就是通過「觸控」的API進行實現,而一些「連續技」,「虛擬搖桿」也需要對應的API組合來實現。

行為:角色的行為就是通過調整角色的屬性而產生的一種結果。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

如移動就是座標

x+=speed;
sprite.play(move);
複製程式碼

角色行為是遊戲邏輯中最重要的一環,而角色之間的行為互動又伴隨著大量的演算法。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

每種遊戲所需要的演算法都不相同,但是遊戲裡執行演算法的計算方式是一致的。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

如加速度方程,在程式碼中的實現實際上如就是

v+=a;
s+=v;
複製程式碼

瞭解遊戲演算法的基本機制後,可以稍微擴充套件下,比如碰撞演算法:

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

基本上每個演算法的推導過程都可以單獨作為一篇文章來講了,感興趣的同學可以自行搜尋演算法名稱。

另外一些比較常用的遊戲演算法也可以瞭解下,比如:狀態機,字典樹,尋路,排序……

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

當然,遊戲基於專業的遊戲引擎去製作,可以達到事半功倍的效果。瞭解遊戲執行機制可以幫你更快速的上手遊戲引擎。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲與傳統web遊戲最大的區別在於API。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

微信小遊戲有一部分與微信小程式不一樣的API。

其中最特別的就是「開放資料」。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

主域可以傳資料到微信後臺,但是卻無法從微信後臺獲取資料。而開放資料域可以從微信後臺獲取資料,但是卻無法現實以及將資料傳入主域。

所以主域想要顯示微信後臺資料,必須在開放資料域繪製好資料,然後將開放資料域的sharedCanvas當作image通過drawImage函式繪製到主域的canvas中。

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會

開放資料的一些注意事項

  1. sharedCanvas 只能被繪製到上屏 canvas 上。

  2. 上屏 canvas 不能呼叫 toDataURL,其 context 不能呼叫 getImageData。

  3. sharedCanvas 不能呼叫 toDataURL 和 getContext。

  4. 不能將上屏 canvas 和 sharedCanvas 以任意形式繪製到其他 canvas 上,包括 drawImage、createPattern、texImage2D、texSubImage2D。

  5. sharedCanvas 的寬高只能在主域設定

其中第5條常常容易被忽略,然後出現各種適配問題。


最後總結一下小遊戲的執行機制。

  • 遊戲從入口檔案進入以後,開始執行渲染器。

  • 然後遊戲的主邏輯會呼叫遊戲下一步需要的場景模組。

  • 場景模組中呼叫當前場景所需要的角色模組。

  • 角色模組在接收到不同的指令後會產生不同的行為。

  • 角色行為之間通過大量演算法進行互動,最終產生完整的遊戲效果。



「現場演講的時候,你好像不是這麼說的」

微信小遊戲開發技巧(大會演講內容整理)丨掘金開發者大會


相關文章