• <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>

            公告

            聯系我:我的126郵箱: billhsu。 Locations of visitors to this page
            <2010年3月>
            28123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            統計

            • 隨筆 - 41
            • 文章 - 0
            • 評論 - 82
            • 引用 - 0

            常用鏈接

            留言簿(16)

            隨筆分類

            隨筆檔案

            相冊

            Game Dev

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            靠得住的休眠函數XSleep
            直接用timeGetTime()這個函數的誤差是有目共睹的,在15ms左右,于是,如果游戲的消息循環用了timeGetTime(),那么3D游戲畫面會因為兩幀之間時間誤差大而有些抖動。
            今天在csdn上看到了一篇文章:http://blog.csdn.net/lanzhengpeng2/archive/2008/05/06/2401554.aspx
            講的也正好是這個問題,記錄一下。

            在使用timeGetTime()的代碼塊的前后加上timeBeginPeriod(1)和timeEndPeriod(1),就可以提高timeGetTime()的精度。

            同時,可以利用timeSetEvent寫了一個靠得住的休眠函數[代碼來自上述文章]:
            static void XSleep(DWORD dwDelay,HANDLE hEvent)
             {
              MMRESULT hTimer 
            = timeSetEvent(dwDelay,1,(LPTIMECALLBACK)hEvent,0,TIME_ONESHOT | TIME_CALLBACK_EVENT_SET);
              MsgWaitForMultipleObjectsEx(
            1,&hEvent,INFINITE,QS_ALLINPUT,0); //當有Windows消息時,還能繼續處理Windows消息。故選擇了這個函數。
              timeKillEvent(hTimer);
             }

            消息循環[代碼來自上述文章]:
             MSG msg;
             DWORD dwLastTime;
             HANDLE hSleepEvent 
            = CreateEvent(NULL,FALSE,FALSE,NULL);

             timeBeginPeriod(
            1);

             dwLastTime 
            = timeGetTime();
             
            while(isActive())
             {
              
            //需要一直處理Windows消息到無消息處理為止
              for(;PeekMessage(&msg,NULL,0,0,PM_REMOVE);)
              {
               
            if(msg.message == WM_QUIT)
               {
                CloseHandle(hSleepEvent);
                timeEndPeriod(
            1);
                
            return ;
               }
               
            if(!TranslateAccelerator(msg.hwnd,hAccelTable,&msg))
               {
                TranslateMessage(
            &msg);
                DispatchMessage(
            &msg);
               }
              }

              DWORD FrameDelay 
            = max(1,1000/max(1,GetMaxFPS()));
              DWORD dwTime 
            = timeGetTime();
              
            if(dwLastTime + FrameDelay > dwTime)
              {
               XSleep(dwLastTime 
            + FrameDelay - dwTime,hSleepEvent);
              }
              
            else
              {
               update();
               dwLastTime 
            += ((dwTime - dwLastTime) / FrameDelay) * FrameDelay; //當實際幀數嚴重低于預期幀數時,這段代碼可以完成跳幀功能;當實際幀數大于等于預期幀數時,這段代碼仍然可以使幀之間的時間間隔固定。之前謝Boss沒有處理好的主要就是這個。
              }
             }

             CloseHandle(hSleepEvent);
             timeEndPeriod(
            1);
            這樣,時間誤差就會在1ms之內了,游戲也就不會抖動了。

            posted on 2010-07-30 10:55 Bill Hsu 閱讀(1592) 評論(0)  編輯 收藏 引用 所屬分類: C/C++Game Dev

            国产免费久久久久久无码| 久久久久99这里有精品10 | 久久av无码专区亚洲av桃花岛| 久久综合偷偷噜噜噜色| 久久婷婷五月综合国产尤物app| 99久久综合狠狠综合久久止| 久久国产精品一区| 久久久老熟女一区二区三区| 久久久精品久久久久久| 久久精品国产亚洲AV无码麻豆 | 欧美噜噜久久久XXX| 97精品伊人久久久大香线蕉| 久久久久久久97| 国产一区二区精品久久凹凸| 久久久久久久人妻无码中文字幕爆 | 久久国产免费| 国产精品久久久久影视不卡| 中文字幕乱码久久午夜| 久久青青草原精品国产软件| 久久久久久综合一区中文字幕| 97久久国产露脸精品国产| 久久中文精品无码中文字幕| 亚洲天堂久久精品| 久久精品国产免费| 国产精品久久网| 九九精品99久久久香蕉| 性欧美丰满熟妇XXXX性久久久| 久久精品中文字幕大胸| 国产成人久久精品麻豆一区| 天天综合久久久网| 亚洲一区二区三区日本久久九| 99久久婷婷免费国产综合精品| 91精品国产高清91久久久久久 | 亚洲国产精品热久久| 91精品国产色综合久久| 国产成人无码久久久精品一| 久久se精品一区精品二区| 久久最近最新中文字幕大全| 久久精品国产亚洲欧美| 激情久久久久久久久久| 欧美精品丝袜久久久中文字幕|