mirror of
https://github.com/doitsujin/dxvk.git
synced 2024-12-14 00:48:44 +01:00
[dxvk] Add more dynamic state to DxvkCommandList
This commit is contained in:
parent
a683ecd525
commit
e01ffc02a8
@ -699,6 +699,25 @@ namespace dxvk {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void cmdSetDepthBoundsState(
|
||||||
|
VkBool32 depthBoundsTestEnable) {
|
||||||
|
m_vkd->vkCmdSetDepthBoundsTestEnableEXT(m_execBuffer, depthBoundsTestEnable);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void cmdSetDepthState(
|
||||||
|
VkBool32 depthTestEnable,
|
||||||
|
VkBool32 depthWriteEnable,
|
||||||
|
VkCompareOp depthCompareOp) {
|
||||||
|
m_vkd->vkCmdSetDepthTestEnableEXT(m_execBuffer, depthTestEnable);
|
||||||
|
|
||||||
|
if (depthTestEnable) {
|
||||||
|
m_vkd->vkCmdSetDepthWriteEnableEXT(m_execBuffer, depthWriteEnable);
|
||||||
|
m_vkd->vkCmdSetDepthCompareOpEXT(m_execBuffer, depthCompareOp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void cmdSetEvent(
|
void cmdSetEvent(
|
||||||
VkEvent event,
|
VkEvent event,
|
||||||
VkPipelineStageFlags stages) {
|
VkPipelineStageFlags stages) {
|
||||||
@ -706,6 +725,14 @@ namespace dxvk {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void cmdSetRasterizerState(
|
||||||
|
VkCullModeFlags cullMode,
|
||||||
|
VkFrontFace frontFace) {
|
||||||
|
m_vkd->vkCmdSetCullModeEXT(m_execBuffer, cullMode);
|
||||||
|
m_vkd->vkCmdSetFrontFaceEXT(m_execBuffer, frontFace);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void cmdSetScissor(
|
void cmdSetScissor(
|
||||||
uint32_t scissorCount,
|
uint32_t scissorCount,
|
||||||
const VkRect2D* scissors) {
|
const VkRect2D* scissors) {
|
||||||
@ -714,6 +741,33 @@ namespace dxvk {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void cmdSetStencilState(
|
||||||
|
VkBool32 enableStencilTest,
|
||||||
|
const VkStencilOpState& front,
|
||||||
|
const VkStencilOpState& back) {
|
||||||
|
m_vkd->vkCmdSetStencilTestEnableEXT(
|
||||||
|
m_execBuffer, enableStencilTest);
|
||||||
|
|
||||||
|
if (enableStencilTest) {
|
||||||
|
m_vkd->vkCmdSetStencilOpEXT(m_execBuffer,
|
||||||
|
VK_STENCIL_FACE_FRONT_BIT, front.failOp,
|
||||||
|
front.passOp, front.depthFailOp, front.compareOp);
|
||||||
|
m_vkd->vkCmdSetStencilCompareMask(m_execBuffer,
|
||||||
|
VK_STENCIL_FACE_FRONT_BIT, front.compareMask);
|
||||||
|
m_vkd->vkCmdSetStencilWriteMask(m_execBuffer,
|
||||||
|
VK_STENCIL_FACE_FRONT_BIT, front.writeMask);
|
||||||
|
|
||||||
|
m_vkd->vkCmdSetStencilOpEXT(m_execBuffer,
|
||||||
|
VK_STENCIL_FACE_BACK_BIT, back.failOp,
|
||||||
|
back.passOp, back.depthFailOp, back.compareOp);
|
||||||
|
m_vkd->vkCmdSetStencilCompareMask(m_execBuffer,
|
||||||
|
VK_STENCIL_FACE_BACK_BIT, back.compareMask);
|
||||||
|
m_vkd->vkCmdSetStencilWriteMask(m_execBuffer,
|
||||||
|
VK_STENCIL_FACE_BACK_BIT, back.writeMask);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void cmdSetStencilReference(
|
void cmdSetStencilReference(
|
||||||
VkStencilFaceFlags faceMask,
|
VkStencilFaceFlags faceMask,
|
||||||
uint32_t reference) {
|
uint32_t reference) {
|
||||||
|
Loading…
Reference in New Issue
Block a user