Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "WinAPI";
Текущий архив: 2004.03.28;
Скачать: [xml.tar.bz2];

Вниз

Проблема с GetTickCount   Найти похожие ветки 

 
SkyRanger ©   (2004-01-09 06:58) [0]

Все еще стражаюсь с таймером прорисовки для своего движка, пытался сделать так:

     NewTickCount:=GetTickCount-StartTickCount;
     if (NewTickCount>OldTickCount) then
     begin
       WinPaint(NewTickCount,OldTickCount);       // Прорисовываем окно
       FPSCnt:=FPSCnt+1; // Увеличиваем счетчик FPS
     end;
     OldTickCount:= GetTickCount-StartTickCount;


Что дало замедление с 86 до 75 FPS
Единственное что удивляет - оба значения NewTickCount и OldTickCount я вывожу на экран, так вот они практически идентичны, т.е. всегда одинаковые, хотя по-идее разница должна в тиках быть довольно большая.

Может я что то неправильно делаю или где то недопонимаю???
Как сделать чтобы задержка обеспечивала одинаковую скорость и на P3 и на P4???


 
Delphi5.01 ©   (2004-01-09 07:21) [1]

Dobroe vrema sutok!
Mne ne ponatno po kakoi prichine, znachenia NewTickCount i OldTickCOunt doljni bit raznia. Posle togo kak vi poluchaete znachenie NewTickCOunt proishotit odin if operator, odna matematicheskoe virajenie + prisvaivanie, nu i pererisovka (vso zvisit ot video karti, na skolko on bistra, i bistro delaet pererisovania). A tolko poesle etogo OldTickCOunt prinimaet svoio novoe znachenie. I ni immet ni kakoi raznici kakaika razniza mejdu StartTickCount daje esli 60 minut to raznica mejdu NewTickCount i OldTickCOunt budet doli secundi.


 
SkyRanger ©   (2004-01-09 07:44) [2]

Ну наскоко я понимаю, GetTickCount возвращает количество миллисекунд с начала работы винды:


The GetTickCount function retrieves the number of milliseconds that have elapsed since Windows was started.

DWORD GetTickCount(VOID)

Parameters

This function has no parameters.

Return Values

If the function succeeds, the return value is the number of milliseconds that have elapsed since Windows was started.


Т.е. каждый раз вызывая GetTickCount я получаю новое значение, т.е. NewTickCount и OldTickCount должны довольно сильно отличаться, так как на прорисовку уходит некоторое количество миллисекунд и точно не 1 и не 10!


 
BiN ©   (2004-01-09 10:29) [3]

кривой у тебя алгоритм
я бы сделал

Tick:=0;
repeat
 GC:=GetTickCount;
 if GC>Tick+Interval then
 begin
   ...
   P:=GC;
 end;
until


 
BiN ©   (2004-01-09 10:33) [4]

....т.е. не P:=GC, а Tick:=GC


 
NAlexey ©   (2004-01-09 10:44) [5]

Для этого надо пользоваться QueryPerformanceCounter и QueryPerformanceFrequency:

var
 t1, t2, Fr: Int64;
begin
 QueryPerformanceFrequency(Fr);
 QueryPerformanceCounter(t1);
 {Do smth}
 QueryPerformanceCounter(t2);
 ShowMessage(FormatDateTime("hh:nn:ss,z", ((t2-t1)/Fr)/86400));
end;


 
panov ©   (2004-01-09 13:41) [6]

function TickCount:Int64;
begin
 QueryPerformanceCounter(Result);
end;

function DeltaTickToSeconds(const Delta: Int64):Double;
var
 TickFreq: Int64;
begin
 QueryPerformanceFrequency(TickFreq);
 Result := Delta/TickFreq;
end;


 
VMcL ©   (2004-01-09 14:22) [7]

>>SkyRanger ©  (09.01.04 06:58)

Может быть еще такая проблема: отключи синхронизацию с вертикальной разверткой (VSync).

P. S. Уж очень числа 86 до 75 близко к стандарнтым частотам 85 и 75 Hz.


 
SkyRanger ©   (2004-01-10 04:35) [8]

Спасибо всем! Попробую то что посоветовали, мож и поможет, надеюсь...


 
SkyRanger ©   (2004-01-13 01:34) [9]

Убрал Vsync FPS сразу подскочил в район 256


 
VMcL ©   (2004-01-15 01:35) [10]

>>SkyRanger ©  (13.01.04 01:34) [9]

Отож.



Страницы: 1 вся ветка

Форум: "WinAPI";
Текущий архив: 2004.03.28;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.04 c
7-1073425700
Cure
2004-01-07 00:48
2004.03.28
GetKeyNames


14-1077891021
Cosinus
2004-02-27 17:10
2004.03.28
Подскажите, как сделать такой Edit . Замучался уже подбирать.


8-1069105502
oens
2003-11-18 00:45
2004.03.28
Как, сделать, спектроанализатор ,как в winamp e ?


3-1075195078
13-ый
2004-01-27 12:17
2004.03.28
Номер записи


1-1078237170
Igor G
2004-03-02 17:19
2004.03.28
Вопрос по ActiveX





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский