您的位置:首页 > 其它

DXUT框架剖析(11)

2016-06-20 00:00 316 查看
DXUT统计函数

函数
描述

DXUTGetFPS
获取当前每秒提交的帧数

DXUTGetFrameStats
获取一个指向字符串的指针,该字符串包括每秒帧数、分辨率、后台缓冲区格式、深度缓冲区格式。

DXUTGetDeviceStats
获取一个指向字符串的指针,该字符串包括当前设备类型、顶点运算行为和设备名。

DXUTGetFPS

Get the current number of frames being presented per second.

 FLOAT DXUTGetFPS()  ;

Parameters
None.

Return Values
The current number of frames being presented per second.

DXUTGetFrameStats

Get a pointer to a string containing the current number of frames per second (optionally), resolution, back buffer format, and depth stencil format.

 LPCWSTR DXUTGetFrameStats(
 bool   bIncludeFPS
 )  ;

Parameters

bIncludeFPS

[in] If true, the string returned will contain the frames per second. Otherwise, it will not.

Return Values
Pointer to a string containing the current number of frames per second (optionally), resolution, back buffer format, and depth stencil format.

DXUTGetDeviceStats

Get a pointer to a string containing the current device type, vertex processing behavior, and device name.

 LPCWSTR DXUTGetDeviceStats()  ;

Parameters
None.

Return Values
Pointer to a string containing the current device type, vertex processing behavior, and device name.

DXUT时间函数

函数
描述

DXUTGetTime
获取当前时间(秒)

DXUTGetElapsedTime
获取从上一帧到当前帧所经过的时间

DXUTSetConstantFrameTime
启用或禁用固定帧时间

DXUTGetTime

Get the current time, in seconds.

 DOUBLE DXUTGetTime()  ;

Parameters
None.

Return Values
The current time, in seconds.

Remarks
DXUT internally uses the best practices for high resolution timing information as described in the "Game Timing and Multicore Processors" article in the DirectX SDK.

DXUTGetElapsedTime

Get the time elapsed since the last frame.

 FLOAT DXUTGetElapsedTime()  ;

Parameters
None.

Return Values
Time elapsed, in seconds, since the last frame.

Remarks
DXUT internally uses the best practices for high resolution timing information as described in the "Game Timing and Multicore Processors" article in the DirectX SDK.

DXUTSetConstantFrameTime

Enables or disables a constant frame time.

 HRESULT DXUTSetConstantFrameTime(
 BOOL   bEnabled   ,
 FLOAT   fTimePerFrame
 )  ;

Parameters

bEnabled

[in] If TRUE, a constant frame time will be enabled.

fTimePerFrame

[in] Time per frame, in seconds. The default value is 0.0333f, so the fTime parameter of LPDXUTCALLBACKFRAMEMOVE and the render callback functions will advance one second for every 30 frames.

Return Values
If the function succeeds, the return value is S_OK. If the function fails, the return value can be one of the error codes in DXUTERR.

Remarks
This function simulates a fixed-frame rate render loop by sending a constant value for elapsed time to the LPDXUTCALLBACKFRAMEMOVE and render callback functions. The default rate is one second for every 30 frames. The application itself will continue to render at an unregulated rate (which may be far higher than the specified frame rate).

This function is useful for saving the rendered output to a video format for playback, allowing animation at a rate independent of the actual rate at which frames were rendered.

DXUT计时器函数

函数
描述

DXUTSetTimer
添加一个新的计时器

DXUTKillTimer
卸载一个已有的计时器

DXUTSetTimer

Starts a DXUT timer that will trigger a callback function at regular intervals.

 HRESULT DXUTSetTimer(
 LPDXUTCALLBACKTIMER   pCallbackTimer   ,
 FLOAT   fTimeoutInSecs   ,
 UINT *   pnIDEvent   ,
 void *   pCallbackUserContext
 )  ;

Parameters

pCallbackTimer

[in] Pointer to a timer callback function. The callback function is to be called at the specified fTimeoutInSecs timeout intervals. May not be NULL.

fTimeoutInSecs

[in] Interval, in seconds, between successive calls to the timer callback function. The default value is 1.0f.

pnIDEvent

[in] Optional pointer to a variable to receive the event ID for the new timer. This event ID will be passed to the timer callback function to indicate which timer generated the event, allowing the application to use a single callback function for multiple timers. The default value is NULL.

pCallbackUserContext

[in] Pointer to a user-defined value which is passed to the callback function. Typically used by an application to pass a pointer to a data structure that provides context information for the callback function. The default value is NULL

Return Values
If the function succeeds, the return value is S_OK. If the function fails, the return value can be one of the error codes in DXUTERR.

Remarks
Timers created with DXUTSetTimer can be destroyed with DXUTKillTimer.

LPDXUTCALLBACKTIMER

A timer to be called at specified time intervals by DXUT.

 VOID LPDXUTCALLBACKTIMER(
 UINT   idEvent   ,
 void*   pUserContext
 )  ;

Parameters

idEvent

[in] Specifies a nonzero timer event ID. Indicates which timer generated the event, allowing the application to use a single callback function for multiple timers.

pUserContext

[in] Pointer to a user-defined value which is passed to the callback function. Typically used by an application to pass a pointer to a data structure that provides context information for the callback function. The default value is NULL

Return Values
No return value.

Remarks
DXUT will call this function at the start of the frame, before calling LPDXUTCALLBACKFRAMEMOVE or LPDXUTCALLBACKD3D10FRAMERENDER.

DXUTKillTimer

Uninstalls an existing timer.

 HRESULT DXUTKillTimer(
 UINT   nIDEvent
 )  ;

Parameters

nIDEvent

[in] The event ID for the timer being destroyed. This ID is provided to the application by the DXUTSetTimer method.

Return Values
If the function succeeds, the return value is S_OK. If the function fails, the return value can be one of the error codes in DXUTERR.

Remarks
Timers created with DXUTSetTimer can be destroyed with DXUTKillTimer .
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: