IDirect3DDevice9::BeginScene 方法 (d3d9helper.h)

开始场景。

语法

HRESULT BeginScene();

返回值

类型: HRESULT

如果方法成功,则返回值D3D_OK。 如果在 IDirect3DDevice9::BeginScene IDirect3DDevice9::EndScene 对中调用 了 IDirect3DDevice9:/:BeginScene ,则该方法将失败并D3DERR_INVALIDCALL。 仅当在不首先调用 IDirect3DDevice9::EndScene 的情况下调用 IDirect3DDevice9::BeginScene 两次时,才会发生这种情况。

注解

应用程序必须在执行任何呈现之前调用 IDirect3DDevice9::BeginScene ,并且必须在呈现完成时调用 IDirect3DDevice9::EndScene ,然后再调用 IDirect3DDevice9::BeginScene

如果 IDirect3DDevice9::BeginScene 失败,则设备无法开始场景,并且无需调用 IDirect3DDevice9::EndScene。 事实上,如果以前的 IDirect3DDevice9::BeginScene 失败,对 IDirect3DDevice9::EndScene 的 调用将失败。 这适用于创建多个交换链的任何应用程序。

任何连续调用之间都应有一个 IDirect3DDevice9::BeginScene/IDirect3DDevice9::EndScene 对,以 (IDirect3DDevice9::P resentIDirect3DSwapChain9::P resent) 。 在执行任何呈现之前,应调用 IDirect3DDevice9::BeginScene 一次,在帧的所有呈现提交到运行时后,应调用一次 IDirect3DDevice9::EndScene。 多个非嵌套 IDirect3DDevice9::BeginScene/IDirect3DDevice9::EndScene 对之间的调用是合法的,但具有多个对可能会导致性能下降。 若要在 CPU 和图形加速器之间实现最大并行度,最好在调用 present 之前调用 IDirect3DDevice9::EndScene

要求

要求
目标平台 Windows
标头 d3d9helper.h (包括 D3D9.h)
Library D3D9.lib

另请参阅

IDirect3DDevice9