Поделиться через


функция обратного вызова PFND3D11DDI_DRAWINSTANCEDINDIRECT (d3d10umddi.h)

Функция DrawInstancedIndirect рисует определенные экземпляры неиндексированных примитивов.

Синтаксис

PFND3D11DDI_DRAWINSTANCEDINDIRECT Pfnd3d11ddiDrawinstancedindirect;

void Pfnd3d11ddiDrawinstancedindirect(
  D3D10DDI_HDEVICE unnamedParam1,
  D3D10DDI_HRESOURCE unnamedParam2,
  UINT unnamedParam3
)
{...}

Параметры

unnamedParam1

hDevice [in]

Дескриптор устройства отображения (графический контекст).

unnamedParam2

hBufferForArgs [in]

Дескриптор буфера, который содержит аргументы для обработки DrawInstancedIndirect. Буфер содержит следующую плотно упакованную структуру:

struct DrawInstancedIndirectArgs {
  UINT VertexCountPerInstance; 
  UINT InstanceCount;
  UINT StartVertexLocation;
  UINT StartInstanceLocation;
}

Дополнительные сведения об этих аргументах см. на странице справки DrawInstanced.

unnamedParam3

AlignedByteOffsetForArgs [in]

Смещение в байтах в буфер, который hBufferForArgs. AlignedByteOffsetForArgs должно быть несколькими из четырех.

Возвращаемое значение

Никакой

Замечания

Драйвер может использовать функцию обратного вызова pfnSetErrorCb для задания кода ошибки.

Функция DrawInstancedIndirect выполняет ту же задачу, что и вызов функции DrawInstance d драйвера. Однако DrawInstancedIndirect получает сведения о неиндексированных примитивах из содержимого буфера, указанного параметром hBufferForArgs. DrawInstancedIndirect считывает содержимое буфера, начиная с смещения байтов, указанного параметром AlignedByteOffsetForArgs.

Когда среда выполнения Direct3D вызывает драйвера CreateResource(D3D11) функцию для создания буферного ресурса, указанного параметром hBufferForArgs, среда выполнения должна задать флаг D3D11_DDI_RESOURCE_MISC_DRAWINDIRECT_ARGS в MiscFlags член структуры D3D11DDIARG_CREATERESOURCE.

Драйвер не должен столкнуться с ошибкой, за исключением D3DDDIERR_DEVICEREMOVED. Таким образом, если драйвер передает любую ошибку, за исключением D3DDDIERR_DEVICEREMOVED, при вызове функции pfnSetErrorCb среда выполнения Direct3D определяет, что ошибка является критической. Даже если устройство удалено, драйвер не требуется возвращать D3DDDIERR_DEVICEREMOVED; Однако если удаление устройства препятствует работе DrawInstancedIndirect (что обычно не должно произойти), драйвер может вернуть D3DDDIERR_DEVICEREMOVED.

Требования

Требование Ценность
минимальные поддерживаемые клиентские DrawInstancedIndirect поддерживается начиная с операционной системы Windows 7.
целевая платформа Настольный
заголовка d3d10umddi.h (include D3d10umddi.h)

См. также

CreateResource(D3D11)

D3D11DDIARG_CREATERESOURCE

D3D11DDI_DEVICEFUNCS

DrawInstanced

pfnSetErrorCb