• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Error

            C++博客 首頁 新隨筆 聯系 聚合 管理
              217 Posts :: 61 Stories :: 32 Comments :: 0 Trackbacks
            星座物語客戶端分析---01物品編輯器
            一、整體設計思路猜測
            1.前期目標數據結構盡可能單一化,配置化。
            2.盡可能讓程序和策劃的接口無人化,工具化,歸納需求以后程序提供工具給策劃人員。
            二、數據結構分析
            所有的道具都被冗余到同一個數據結構中了。
            優勢:編碼、和配置文件的制作上非常方便
            劣勢:內存略高,后期編碼肯能會有負擔
            *所有游戲世界中任何道具都可以用_ITEM_TABLE結構體來描述
            三、類型邏輯分析
            目前分析到的代碼,可以看出來,道具是“二級”分類,前期考慮也不夠充分,后面添加的代碼略顯混亂。
            第一級:醫療道具、裝備道具、輔助道具、任務道具(道具觸發任務、道具觸發技能、道具觸發循環任務)
            第二級:
              醫療道具二級分類:HP、MP、HPMP、Fealty(寵物忠誠度)、Health
              裝備道具二級分類:武器、頭部、衣服、手套、鞋子、項鏈、戒子、肩部
              *任務道具二級分類(實際代碼被卸載一級分類中了):道具觸發任務、道具觸發循環任務
              *輔助道具二級分類(實際代碼被卸載一級分類中了):道具觸發技能、ect.
            四、細節分析:
            1.對武器強化(打寶石,打孔)的支持不夠好。
            猜測_ITEM_TABLE.nNextLevel用于支持強化。實際使用可能強化前,和強化后是完全不同的兩個物品,通過nNextLevel關聯起來。這種設計中每個武器只要是同一類型,那么一定是統一屬性的。
            一個更好的方案是,給每個武器一個GUID,然后可以為武器添加全局唯一的屬性,方便“小極品”,允許更多個性化的存在,同時也可以更好的追蹤物品的交易流轉。這樣需要一個查詢效率足夠高的數據庫來保存游戲中每一個物品的數據。目測可以用KV來解決。如果查詢壓力太大,可以允許數據冗余,將道具的GUID數據和持有玩家綁定起來,一個玩家ID可以批量查詢出其對應的所有道具的GUID數據,直接用blob字段保存起來,同時GUID字段作為日志表保持,只在發生更改的時候才會有寫操作。或者這部分數據用KV數據庫系統保存。
            2.有沒有辦法把_ITEM_TABLE結構體拆分,或者把道具做的靈活一點,變成組建系統或者屬性系統。
            比如:道具看成是一個組建/屬性容器,放了一個裝備組建進去他就具有裝備的功能,放了一個醫療屬性就是一個醫療物品。這樣道具可以更加靈活,比如:將一個裝備作為藥品吃掉。(這個時候一級類型不再是類型,而是屬性,具有裝備道具屬性同時具有道具類型屬性)
            3.降內存
            使用protobuf代替直接使用結構體會不會好一點?_ITEM_TABLE中還使用了std::string作為字段,一個不小心memset就會掛掉。此外protobuf的優勢還有支持optional等配置,可能會有優勢,比如不用更具一級類型去復用二級類型的字段,而是將不同的部分獨立出來作為optional字段。
            五、道具屬性
            基礎屬性(三圍數據):力量(Strength)、敏捷(Agility)、耐力(Stamina)、精神(Energy)、智力(Intellect)、物攻(Attack)、魔攻(Magic)、物防(Recovery)、魔防(Mrecovery)、攻速(AckSpeed)、準確(Nicety)、躲閃(Dodge)
            MP、HP
            體力消耗
            磨損
            價格
            職業
            ect.待續,改天直接分析策劃案子,這個樣子太累
            posted on 2015-03-16 17:43 Enic 閱讀(319) 評論(1)  編輯 收藏 引用 所屬分類: 從零開始寫棋牌游戲平臺

            評論

            # re: 星座物語客戶端分析---01物品編輯器 2015-03-16 18:35 Enic
            后續的技能工具,寵物工具都沒有本質變化,不再這樣分析了。
            整個的思路都是以配置表填充游戲世界,細節上沒有其他亮點,沒有特別出彩的數據結構設計,大部分都是大一統的配置表格。
            后續出一個客戶端整個表格設計的概覽,然后分析其他的東東  回復  更多評論
              

            久久午夜伦鲁片免费无码| 亚洲国产精品无码久久久不卡| 99国产欧美精品久久久蜜芽| 99久久精品国内| 无码任你躁久久久久久久| 热re99久久6国产精品免费| 亚洲国产二区三区久久| 久久久久久久综合狠狠综合| 97久久精品无码一区二区天美| 精品国产青草久久久久福利| 久久久一本精品99久久精品88| 国产午夜精品理论片久久影视 | 久久久久久亚洲精品无码| 久久久国产99久久国产一| 777久久精品一区二区三区无码| 亚洲精品第一综合99久久| 国产91久久综合| 丰满少妇高潮惨叫久久久| 成人综合久久精品色婷婷| 国产真实乱对白精彩久久| 久久免费的精品国产V∧| 一级A毛片免费观看久久精品| 久久美女网站免费| 国产精品免费福利久久| 亚洲精品乱码久久久久久久久久久久 | 久久亚洲天堂| 久久久久久a亚洲欧洲aⅴ| 欧美亚洲色综久久精品国产| 久久综合亚洲鲁鲁五月天| 久久影院亚洲一区| 久久精品免费大片国产大片| 久久国产热这里只有精品| 99久久国产免费福利| 国内精品久久久久影院免费| 国产亚洲精久久久久久无码| 久久香蕉超碰97国产精品| 日本强好片久久久久久AAA| 久久青青草原亚洲av无码app| 久久精品人人槡人妻人人玩AV | 狠狠人妻久久久久久综合| 狠狠精品久久久无码中文字幕 |