• <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
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統計

            • 隨筆 - 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 閱讀(1579) 評論(0)  編輯 收藏 引用 所屬分類: C/C++Game Dev

            亚洲欧美日韩精品久久亚洲区| 久久精品国产影库免费看| 欧美激情精品久久久久久| 色婷婷噜噜久久国产精品12p| 久久99国产精品久久99小说| 久久久久久毛片免费播放| 久久精品国产99国产精品澳门| 热久久国产欧美一区二区精品| 99精品国产在热久久无毒不卡| 欧美国产精品久久高清| 国产欧美一区二区久久| 久久天天躁夜夜躁狠狠| 国产精品丝袜久久久久久不卡 | 久久天天躁狠狠躁夜夜躁2014| 久久久久久夜精品精品免费啦| 久久99精品久久久久久9蜜桃| 久久久久久夜精品精品免费啦| 久久综合视频网站| 91精品国产91久久久久久| 欧洲人妻丰满av无码久久不卡| 久久久久国产一级毛片高清板| 久久99热国产这有精品| 久久er99热精品一区二区| 成人综合久久精品色婷婷| 激情综合色综合久久综合| 国产成人久久精品区一区二区| 欧美久久久久久| 欧美一区二区久久精品| 欧美精品福利视频一区二区三区久久久精品 | 一本久久a久久精品亚洲| 久久最新免费视频| 欧美日韩成人精品久久久免费看| 99热成人精品热久久669| 精品乱码久久久久久久| 日本久久久久亚洲中字幕| 少妇久久久久久久久久| 亚洲精品乱码久久久久久| 99久久精品免费看国产一区二区三区| 久久国产精品免费一区| 久久免费香蕉视频| 久久人人爽人人爽人人片AV麻烦|