• <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>
            隨筆 - 119  文章 - 290  trackbacks - 0

            博客搬家了哦,請移步
            叫我abc

            常用鏈接

            留言簿(12)

            隨筆分類

            我的博客

            搜索

            •  

            積分與排名

            • 積分 - 303769
            • 排名 - 84

            最新評論

            閱讀排行榜

            此前曾思考過腳本如何同程序結合,雖然有所悟,但卻發現連慣的執行某個腳本的時候,某些指令要掛起游戲的行動邏輯,比如TALK,在anykey按下前,整個場景都不能控制,而必須關注在人物對話上。
            這里所說的行動邏輯,是指類似于ACT游戲的主邏輯/主循環,沒有對話,沒有菜單,也沒有腳本。

            先聲明一個常用的術語,windows_game_loop(簡稱wgl),也就是windows下常用的游戲主循環代碼:
            while(run_game)?{
            ??
            while(PeekMessage)?{
            ????
            ??}

            ??
            if?(actived)?{
            ????impl_game_loop();
            ??}

            ??
            else??WaitMessage();
            }

            好了,看看圣劍2所透露的RPG基本模塊:
            1,行動邏輯,也就是主循環game_loop,是一個wgl;
            2,主菜單,CMenu類,包含狀態,物品,魔法子系統。它的run()是一個wgl,因此菜單啟動后,能夠掛起行動邏輯;
            3,腳本系統,會連慣的執行一個腳本文件;
            4,消息隊列,并不是winproc,消息隊列每次每幀只執行一條消息,每幀并不能保證能完成執行,所以下一幀還會執行相同的動作,直到完成并刪除該消息。重要的是,只要消息隊列非空,就不會執行行動邏輯,暫時掛起它;
            5,戰斗系統,包含fight_menu,fight_good,fight_magic之類的東西,類似于一個mini_game。它的start()函數,是一個wgl;
            6,對話系統,將由腳本系統和消息隊列協作完成,對話時要掛起行動邏輯;

            看行動邏輯,主菜單和戰斗系統,它們都是wgl,因此可以單獨封裝成game_moudel,并注冊到game_system下,由它驅動執行。

            行動邏輯是非戰斗時的邏輯,主要內容是控制player的運動,還有當player面向某個NPC并按下“對話鍵”后,觸發該NPC執行其腳本。行動邏輯只能在空消息隊列時才執行,這很重要。

            對話系統。連續的對話,來源于NPC的腳本。NPC的腳本一口氣的執行,但是對話必須一步步等待交互的來,如何做到?圣劍的解決方案是把對話指令轉成消息,并放到消息隊列中。
            消息隊列在wgl中掛起行動邏輯,使得player關注到對話上。消息隊列執行一個NPC_TALK/PLAYER_TALK命令,顯示對話文字,每幀不斷的重復,直到player按下anykey,消息隊列刪除該消息,執行下一條消息,也許是NPC_TALK/PLAYER_TALK,這樣對話就得到了延續。
            看這樣一個對話腳本,其中每個command都變成消息加入到消息隊列,自然就能掛起行動邏輯完成對話了:
            NPC_TALK?"Hello,?My?friend"
            PLAYER_TALK?
            "Hello,?What's?up"
            NPC_TALK?
            "Maybe?you?need?a?sword"
            PUT_ITEM?sword
            TALK?
            "You?get?a?sword"

            但是,消息隊列并不能很好的解決含選擇項對話的問題,因為不期望腳本被阻塞(多數是由于圖形引擎結構引起,不希望把刷新掛進某個函數內,雖然可以這么做),比如:
            ret?=?NPC_CHOISE("You?are?Saber?"?,"YES"?,"NO")
            if?(ret?==?"YES")
            ??NPC_TALK?
            "Hello,?Saber"
            ??NPC_TALK?
            "I?think?you?need?a?sword"
            ??PUT_ITEM?sword
            ??PLAYER_TALK?
            "Thanks"
            else
            ??NPC_TALK?
            "Oh,?byebye"
            end?
            if
            以上,就是隊列不能解決的腳本···除非NPC_CHOISE是一個wgl
            posted on 2006-12-25 11:03 LOGOS 閱讀(1253) 評論(0)  編輯 收藏 引用
            久久国产综合精品五月天| 久久婷婷色综合一区二区 | 亚洲精品无码久久久久sm| 欧美丰满熟妇BBB久久久| 久久九九有精品国产23百花影院| 丁香五月综合久久激情| 久久久久久久91精品免费观看| 伊人久久精品无码av一区| 久久99国产精一区二区三区| 99久久精品免费观看国产| 久久精品国产精品亚洲精品| 久久综合九色综合欧美狠狠| 一级做a爰片久久毛片免费陪| 久久精品aⅴ无码中文字字幕不卡 久久精品aⅴ无码中文字字幕重口 | 97精品久久天干天天天按摩| 久久久久久久综合日本| 99国产欧美久久久精品蜜芽| 亚洲AⅤ优女AV综合久久久| 国产一区二区三区久久| 97精品依人久久久大香线蕉97| 91久久精品国产成人久久| 亚洲av成人无码久久精品| 午夜精品久久久久9999高清| 97久久精品人人做人人爽| 久久99精品久久久久久hb无码| 久久婷婷是五月综合色狠狠| 国产午夜福利精品久久| 国产精品99久久久久久人| 伊人久久精品无码av一区| 偷偷做久久久久网站| 伊人色综合九久久天天蜜桃| 精品乱码久久久久久夜夜嗨| 久久久中文字幕| 国产精品一区二区久久不卡 | 亚洲嫩草影院久久精品| 波多野结衣中文字幕久久| 亚洲精品tv久久久久久久久| 久久久亚洲AV波多野结衣| 久久久国产精华液| 亚洲人成网亚洲欧洲无码久久| 久久久久99这里有精品10|