функция обратного вызова PFND3D11DDI_CREATEDOMAINSHADER (d3d10umddi.h)
Функция CreateDomainShader создает шейдер домена.
Синтаксис
PFND3D11DDI_CREATEDOMAINSHADER Pfnd3d11ddiCreatedomainshader;
void Pfnd3d11ddiCreatedomainshader(
D3D10DDI_HDEVICE unnamedParam1,
const UINT *pShaderCode,
D3D10DDI_HSHADER unnamedParam3,
D3D10DDI_HRTSHADER unnamedParam4,
const D3D11DDIARG_TESSELLATION_IO_SIGNATURES *unnamedParam5
)
{...}
Параметры
unnamedParam1
hDevice [in]
Дескриптор устройства отображения (графический контекст).
pShaderCode
Массив токенов CONST UINT, образующих код шейдера. Первым маркером в потоке кода шейдера всегда является маркер версии. Следующий маркер в потоке — это маркер длины, определяющий конец потока кода шейдера. Дополнительные сведения о формате кода шейдера Direct3D версии 11 см. в комментариях в файле заголовка D3d11tokenizedprogramformat.hpp , который входит в состав WDK.
unnamedParam3
hShader [in]
Дескриптор личных данных драйвера для шейдера домена. Драйвер возвращает размер (в байтах) области памяти, которую среда выполнения Microsoft Direct3D должна выделить для частных данных при вызове функции CalcPrivateTessellationShaderSize драйвера. Дескриптор — это просто указатель на область памяти, размер которой запрошен драйвером. Драйвер использует эту область памяти для хранения внутренних структур данных, связанных с объектом тесселяции-шейдера.
unnamedParam4
hRTShader [in]
Дескриптор домена, который должен использовать драйвер при обратном вызове в среду выполнения Direct3D.
unnamedParam5
pSignatures [in]
Указатель на структуру D3D11DDIARG_TESSELLATION_IO_SIGNATURES , которая формирует сигнатуру тесселяции-шейдера.
Возвращаемое значение
None
Remarks
Драйвер может использовать функцию обратного вызова pfnSetErrorCb , чтобы задать код ошибки.
Драйвер может передать E_OUTOFMEMORY (если у драйвера заканчивается память) или D3DDDIERR_DEVICEREMOVED (если устройство удалено) в вызове функции pfnSetErrorCb . Среда выполнения Direct3D определяет, что любые другие ошибки являются критическими. Если драйвер передает ошибки, включая D3DDDIERR_DEVICEREMOVED, среда выполнения Direct3D определяет, что дескриптор недопустим; Поэтому среда выполнения не вызывает функцию DestroyShader для уничтожения дескриптора, указанного параметром hShader .
Требования
Требование | Значение |
---|---|
Минимальная версия клиента | CreateDomainShader поддерживается начиная с операционной системы Windows 7. |
Целевая платформа | Персональный компьютер |
Верхняя часть | d3d10umddi.h (включая D3d10umddi.h) |
См. также раздел
CalcPrivateTessellationShaderSize