手?jǐn)]經(jīng)典貪食蛇游戲(附源碼)

前天犯賤登錄了騙子的蘋果ID, 結(jié)果自己的ipad被騙子遠(yuǎn)程鎖定了, 如今變磚頭, 心情很down, 故參考網(wǎng)友的思路自己手?jǐn)]一個(gè)貪食蛇(簡(jiǎn)直班門弄斧).

先上游戲效果圖如下, 界面和諾基亞時(shí)代的貪食蛇差不多:

貪食蛇.gif

這里簡(jiǎn)單說下思路, 文章最后貼上我的源碼github下載地址, 有興趣的大兄弟可以下來看看, 本人最高才玩了52分.

哦恩恩哦.png

首先我們用OC來寫貪食蛇, 那么思想就是要面向?qū)ο蟮? 這里有幾個(gè)主要的類: 蛇, 蛇行走的背景view, 蛇的節(jié)點(diǎn), 還有控制器. 我們就是在這4個(gè)類里面操作.

蛇(Snake): 它是由節(jié)點(diǎn)(Node)組成, 那么用一個(gè)數(shù)組來保存一條蛇的所有節(jié)點(diǎn). 蛇有很多行為(方法), 包括出生(初始化), 吃東西, 長(zhǎng)大, 行走, 停下來.

節(jié)點(diǎn)(Node): 一個(gè)節(jié)點(diǎn)的位置由它的中心點(diǎn)坐標(biāo)來決定, 所以節(jié)點(diǎn)類有一個(gè)centerPoint屬性, 傳入這個(gè)屬性可以創(chuàng)建一個(gè)節(jié)點(diǎn).

如何把蛇創(chuàng)建在界面上

一開始肯定是想著創(chuàng)建image view來表示每個(gè)節(jié)點(diǎn), 那么一條蛇就由好幾個(gè)image view組成, 但是蛇吃東西后會(huì)不斷變長(zhǎng), 最后可能要?jiǎng)?chuàng)建好多個(gè)image view. 我們知道, 在界面上創(chuàng)建過多的控件是影響性能的, 所以我選擇用 Quartz2D 繪圖的方式把蛇繪制出來, 也就是把節(jié)點(diǎn)數(shù)組里面的每個(gè)節(jié)點(diǎn)繪制出來.

如何實(shí)現(xiàn)蛇的行走

一條蛇的位置是由一個(gè)節(jié)點(diǎn)數(shù)組來決定, 數(shù)組的第一個(gè)元素代表蛇頭, 數(shù)組的最后一個(gè)元素代表蛇尾. 讓一條蛇移動(dòng), 其實(shí)就是把節(jié)點(diǎn)數(shù)組的最后一個(gè)節(jié)點(diǎn)元素從數(shù)組中移除, 改一下它的中心點(diǎn)坐標(biāo)為蛇頭節(jié)點(diǎn)的坐標(biāo)再遠(yuǎn)一個(gè)單元格, 接著把這個(gè)節(jié)點(diǎn)放進(jìn)數(shù)組的第0位, 也就是放在原來的蛇頭節(jié)點(diǎn)前面, 讓它變成蛇頭. 然后用一個(gè)repeat為YES的定時(shí)器NSTimer, 不斷的把蛇尾節(jié)點(diǎn)放到蛇頭節(jié)點(diǎn)前面, 然后不斷重繪(手動(dòng)調(diào)用setNeedDisplay方法來觸發(fā)draw rect:方法).
PS: 繪圖操作寫在draw rect:方法里面, 系統(tǒng)會(huì)默認(rèn)調(diào)用一次. 當(dāng)我們手動(dòng)調(diào)用setNeedDisplay方法后會(huì)自動(dòng)再次觸發(fā)draw rect方法.

如何控制蛇的前進(jìn)方向

我用一個(gè)枚舉屬性來記錄蛇的方向,
當(dāng)蛇的方向向上, 節(jié)點(diǎn)的坐標(biāo)x不變, y減一個(gè)單元格;
當(dāng)蛇的方向向下, 節(jié)點(diǎn)的坐標(biāo)x不變, y加一個(gè)單元格;
當(dāng)蛇的方向向左, 節(jié)點(diǎn)的坐標(biāo)x減一個(gè)單元格, y不變;
當(dāng)蛇的方向向右, 節(jié)點(diǎn)的坐標(biāo)x加一個(gè)單元格, y不變.

如何創(chuàng)建食物

食物直接用一個(gè)image view來表示即可, 創(chuàng)建時(shí)候它的坐標(biāo)隨機(jī), 但是要注意要控制食物不能創(chuàng)建在蛇身上.

蛇吃食物的過程

當(dāng)蛇頭的坐標(biāo)等于食物的坐標(biāo), 表示蛇吃了食物, 這時(shí)候要做3件事:
1.重新隨機(jī)位置創(chuàng)建食物.
2.蛇要往蛇尾方向變長(zhǎng)一格: 前面說了, 蛇移動(dòng)時(shí)候我要把節(jié)點(diǎn)數(shù)組最后一個(gè)節(jié)點(diǎn)移除取出來. 在我把節(jié)點(diǎn)數(shù)組中的蛇尾節(jié)點(diǎn)從數(shù)組中移除的時(shí)候, 注意!這個(gè)位置是沒有節(jié)點(diǎn)了,當(dāng)蛇吃了食物后, 我們創(chuàng)建一個(gè)新的節(jié)點(diǎn), 放在這個(gè)位置, 就可以實(shí)現(xiàn)蛇變長(zhǎng)了一格. 所以需要用屬性保存記錄一下這個(gè)蛇尾節(jié)點(diǎn)的原坐標(biāo)lastPoint, 吃到食物后用這個(gè)坐標(biāo)創(chuàng)建一個(gè)新的節(jié)點(diǎn)放在這里.
3.分?jǐn)?shù)+1.

核心的思路已經(jīng)說完了, 剩下的就是自己在邊敲代碼過程中邊修正一些細(xì)節(jié)的業(yè)務(wù)邏輯, 比如蛇頭碰到邊界或者碰到自己就會(huì)game over.

該demo只實(shí)現(xiàn)了最原始的貪食蛇, 還可以不斷的豐富和優(yōu)化它的功能和玩法的, 這個(gè)以后再慢慢弄了.

demo的源碼下載地址如下, 裝在自己的手機(jī)里玩玩還是有那么一點(diǎn)無(wú)聊的:
https://github.com/imbawales/Hungry-Snake

最后良心建議, 千萬(wàn)不要在自己的蘋果設(shè)備上登錄別人的蘋果ID, 以及自己的蘋果ID一定要上官網(wǎng)弄2級(jí)保護(hù)防止被盜.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,182評(píng)論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,489評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,290評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,776評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,510評(píng)論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,866評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,860評(píng)論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,036評(píng)論 0 290
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,585評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,331評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,536評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,058評(píng)論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,754評(píng)論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,154評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,469評(píng)論 1 295
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,273評(píng)論 3 399
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,505評(píng)論 2 379

推薦閱讀更多精彩內(nèi)容

  • 前言 閑著沒事干,想起多年前學(xué)java時(shí),筆者擼過的俄羅斯方塊,坦克大戰(zhàn),貪食蛇,現(xiàn)如今已拋棄java多年,投入i...
    codingZero閱讀 8,116評(píng)論 12 54
  • 很久很久以前,差不多大半年前吧,筆者發(fā)布了一篇關(guān)于OC版貪食蛇開發(fā)的文章,時(shí)隔多月,微信小程序橫空出世,于是閑來無(wú)...
    codingZero閱讀 5,843評(píng)論 9 36
  • #史上最詳細(xì)的C語(yǔ)言貪吃蛇教程 #前言 在有用C寫貪吃蛇的一個(gè)想法之后,上網(wǎng)查了幾個(gè)教程,覺得不是很能看懂。恩。。...
    iimT閱讀 33,279評(píng)論 19 30
  • 關(guān)于于小程序筆者就不做介紹了,官方有詳細(xì)文檔,我們還是先來看張圖吧 就是這個(gè)樣子的,游戲界面跟之前的OC版是差不多...
    Programmer客棧閱讀 2,589評(píng)論 0 0
  • 在這深秋 送走迎來 我用棉衣送走了秋 曾朝我微笑的花兒以凋謝成實(shí) 豐碩的果實(shí)伴著汗水迎來微笑 憨厚的笑臉如曇花一現(xiàn)...
    旅途的泡面閱讀 124評(píng)論 1 1