Condividi tramite


Metodo ID3D11DeviceContext::CSSetConstantBuffers (d3d11.h)

Imposta i buffer costanti utilizzati dalla fase compute-shader.

Sintassi

void CSSetConstantBuffers(
  [in]           UINT         StartSlot,
  [in]           UINT         NumBuffers,
  [in, optional] ID3D11Buffer * const *ppConstantBuffers
);

Parametri

[in] StartSlot

Tipo: UINT

Indice nella matrice in base zero per iniziare a impostare i buffer costanti su (intervallo compreso tra 0 e D3D11_COMMONSHADER_CONSTANT_BUFFER_API_SLOT_COUNT - 1).

[in] NumBuffers

Tipo: UINT

Numero di buffer da impostare (compreso tra 0 e D3D11_COMMONSHADER_CONSTANT_BUFFER_API_SLOT_COUNT - StartSlot).

[in, optional] ppConstantBuffers

Tipo: ID3D11Buffer*

Matrice di buffer costanti (vedere ID3D11Buffer) assegnati al dispositivo.

Valore restituito

nessuno

Osservazioni

Il metodo conterrà un riferimento alle interfacce passate. Questo comportamento differisce dal comportamento dello stato del dispositivo in Direct3D 10.

Il runtime direct3D 11.1, disponibile a partire da Windows 8, può associare un numero maggiore di risorse ID3D11Buffer allo shader rispetto alle dimensioni massime del buffer costante supportate dagli shader (costanti 4096 - componenti a 4*32 bit ciascuno). Quando si associa un buffer di grandi dimensioni, lo shader può accedere solo alle prime costanti dei componenti a 4096 4*32 bit nel buffer, come se 4096 costanti corrispondano alle dimensioni complete del buffer.

Se l'applicazione vuole che lo shader acceda ad altre parti del buffer, deve chiamare invece il metodo CSSetConstantBuffers1 .

Requisiti

Requisito Valore
Piattaforma di destinazione Windows
Intestazione d3d11.h
Libreria D3D11.lib

Vedi anche

ID3D11DeviceContext