flappy pig小遊戲源碼分析(2)——解剖option

今天繼續分析flappy bird的源碼。重溫一下源碼的目錄結構。css

在本系列第一篇中咱們分析了game.js文件,也就是整個程序的架構。這一篇咱們來看看option.js文件,這個文件的內容很簡單,主要是配置一些遊戲中各種元素的參數。架構

咱們仍是按照慣例先上源代碼:app


var flappy = (function (self) {
    'use strict';

    //設置
    self.option = {
        //重力加速度,屏幕像素和實際物理上的米有差異,因此存在換算
        g: 400,
        //跳躍的初速度,控制豬的彈跳力
        v0: 400,
        //柱子移動速度
        vp: 2.5,
        //頻率,控制動畫幀數,默認20ms
        frequency: 20,
        //關卡數
        levels: 100,
        //開頭的空白距離
        safeLift: 500,

        //地板高度(和圖片有關)
        floorHeight: 64,

        //豬的寬度
        pigWidth: 33,
        //豬的高度
        pigHeight: 30,
        //豬當前高度
        pigY: 300,
        //豬距離左邊的距離,
        pigLeft: 80,

        //柱子Html
        pillarHtml: '<div class="top"></div><div class="bottom"></div>',
        //柱子寬度
        pillarWidth: 45,
        //柱子上下間隔高度
        pillarGapY: 108,
        //柱子左右間隔寬度
        pillarGapX: 250,
        //上柱子的基礎定位值(就是top值,和css寫法有關)
        pillarTop: -550,
        //下柱子的基礎定位值
        pillarBottom: -500
    };

    return self;//這個執行完以後flappy就是一個含有option屬性的對象了

})(flappy || {});

關於其中var flappy = (function(self){模塊化

//其餘細節動畫

})(flappy || {})的用法若是仍是不太理解,能夠再去看看本系列的第一篇。spa

看完這個源碼我相信絕大多數同窗都沒有一點壓力,惟一可能產生疑問的就是,爲何要這麼作呢?咱們爲何要單獨的用一個文件來專門存放這些配置參數呢?設計

咱們常常聽到關於程序設計的一些專業術語如:低耦合、高內聚、可維護性、模塊化等等,先拋開這些模糊的概念不談,咱們來講說現實生活中隨處可見的一個概念——單一職責原則。code

大掃除的時候,掃地的同窗只負責掃地、擦玻璃的同窗只負責擦玻璃、擦黑板的同窗只負責擦黑板,你們各司其職互不牽涉。檢查的時候發現地沒有掃乾淨,那就確定是掃地同窗的責任,相應的玻璃沒幹淨就找擦玻璃的同窗來負責。一旦掃地的同窗不只負責掃地,同時還順便幫忙擦擦玻璃的話,檢查時若是發現玻璃沒擦乾淨,這個時候想要知道誰負責的話就很很麻煩了,起碼要把兩我的叫來問個清楚,說不定他倆再互相推脫一下。在程序設計中咱們把各司其職個安其分稱之爲單一職責原則,一旦出了任何問題,咱們能很快的找到哪一個模塊該對問題負責。對象

瞭解了什麼是單一職責原則,咱們再來看看這個option.js文件,咱們很容易的就會知道,這個option.js文件的職責就是配置遊戲參數供其它模塊使用,一旦須要調整參數,好比我要把豬變大一點,把柱子之間的距離加大一點同時把地板額高度設高一點,我只須要更改option.js文件就能夠了,改完後他會馬上反應到每一個引入他的文件中去。若是你把這些配置項分別寫在各自的模塊中,那麼一旦須要調整,你能夠想象你有多麼痛苦。blog

這一節的內容很簡單,可是須要讀者本身加深理解,造成程序設計的思想並加以運用。

相關文章
相關標籤/搜索