C++ C++;D3D9 Alpha与创建者混合更新

C++ C++;D3D9 Alpha与创建者混合更新,c++,directx,C++,Directx,目前我正在开发一个使用dx9创建覆盖的应用程序。 现在我遇到了一个问题,它无法使用alpha通道,因为我将Windows 10升级到了最新版本(创建者更新) 例如,如果我试图渲染一个透明的矩形,它总是保持100%可见 设置 渲染方法 函数调用 有什么建议吗?在更新之前它工作得很好…我现在自己找到了解决方案 我不得不删除ULW_COLORKEY选项,该选项旨在使用crkey作为透明度颜色。对于最新的creator更新,这可能无法正常工作。如果禁用MSAA,它会工作吗?可能将CS\u PARENTD

目前我正在开发一个使用dx9创建覆盖的应用程序。 现在我遇到了一个问题,它无法使用alpha通道,因为我将Windows 10升级到了最新版本(创建者更新) 例如,如果我试图渲染一个透明的矩形,它总是保持100%可见

设置

渲染方法

函数调用


有什么建议吗?在更新之前它工作得很好…

我现在自己找到了解决方案


我不得不删除ULW_COLORKEY选项,该选项旨在使用crkey作为透明度颜色。对于最新的creator更新,这可能无法正常工作。

如果禁用MSAA,它会工作吗?可能将
CS\u PARENTDC
设置为窗口类样式和/或不设置颜色键会有所帮助?谢谢您的建议!不幸的是,它不起作用。。到目前为止,我尝试的是通过设置D3DRS_ALPHABLENDENABLE和D3DRS_SeparatealAlphablendenable来稍微搅乱渲染设置,这会创建一个“更暗的”rect,例如,使用颜色键0x3F00FF00,但仍然没有alpha渲染..哦,我注意到另一件奇怪的事情是,将颜色键设置为0xXX000000会创建一个完全透明的rect,而不是黑色的rect。颜色键可能有问题吗?它与旧的Windows10版本很好地用于共享,今天遇到了这个问题,删除ULW_COLORKEY解决了这个问题。
WNDCLASSEX wc = {
    sizeof(WNDCLASSEX),
    0,
    WndProc,
    0,
    0,
    nullptr,
    LoadIcon(nullptr, IDI_APPLICATION),
    LoadCursor(nullptr, IDC_ARROW),
    nullptr,
    nullptr,
    OverlayName.c_str(),
    LoadIcon(nullptr, IDI_APPLICATION)
};

if (!RegisterClassEx(&wc))
    return false;

m_hWndOverlay = CreateWindowEx(WS_EX_TOPMOST | WS_EX_TRANSPARENT | WS_EX_LAYERED,
    OverlayName.c_str(),
    OverlayName.c_str(),
    WS_POPUP, CW_USEDEFAULT, CW_USEDEFAULT, 800, 600, nullptr, nullptr, nullptr, nullptr);

if (!m_hWndOverlay)
    return false;

if (!SetLayeredWindowAttributes(m_hWndOverlay, RGB(NULL, NULL, NULL), 255, ULW_COLORKEY | LWA_ALPHA))
    return false;

static MARGINS  DWMMargins = { -1, -1, -1, -1 };
if (!HR(DwmExtendFrameIntoClientArea(m_hWndOverlay, &DWMMargins), "DwmExtendFrameIntoClientArea()"))
    return false;

ShowWindow(m_hWndOverlay, SW_SHOWDEFAULT);
if (!UpdateWindow(m_hWndOverlay))
    return false;

if (!HR(Direct3DCreate9Ex(D3D_SDK_VERSION, &m_pDirect3D9Ex),        "Direct3DCreate9Ex()"))
    return false;

D3DPRESENT_PARAMETERS params;
ZeroMemory(&params, sizeof(D3DPRESENT_PARAMETERS));

params.Windowed = TRUE;
params.SwapEffect = D3DSWAPEFFECT_DISCARD;
params.BackBufferFormat = D3DFMT_A8R8G8B8;
params.EnableAutoDepthStencil = TRUE;
params.AutoDepthStencilFormat = D3DFMT_D16;
params.MultiSampleType = D3DMULTISAMPLE_NONE;
params.PresentationInterval = 0x80000000L;
DWORD dwMSQAAQuality = 0;

if (HR(m_pDirect3D9Ex->CheckDeviceMultiSampleType(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, D3DFMT_A8R8G8B8, true, D3DMULTISAMPLE_NONMASKABLE, &dwMSQAAQuality), "CheckDeviceMultiSampleType()"))
{
    params.MultiSampleType = D3DMULTISAMPLE_NONMASKABLE;
    params.MultiSampleQuality = dwMSQAAQuality - 1;
}

if (!HR(m_pDirect3D9Ex->CreateDeviceEx(D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, m_hWndOverlay, D3DCREATE_HARDWARE_VERTEXPROCESSING, &params, nullptr, &m_pDirect3D9Device), "CreateDeviceEx()"))
    return false;
void DrawFilledRect(float x, float y, float w, float h, DWORD color) const
{
VERTEX_2D_DIF V[4];

V[0].color = V[1].color = V[2].color = V[3].color = color;

V[0].z = V[1].z = V[2].z = V[3].z = 0;
V[0].rhw = V[1].rhw = V[2].rhw = V[3].rhw = 1;

V[0].x = x;
V[0].y = y;
V[1].x = x + w;
V[1].y = y;
V[2].x = x + w;
V[2].y = y + h;
V[3].x = x;
V[3].y = y + h;

m_pDirect3D9Device->SetFVF(VERTEX_2D_DIF::FVF);
m_pDirect3D9Device->DrawPrimitiveUP(D3DPT_TRIANGLEFAN, 2, &V, sizeof(VERTEX_2D_DIF));
}
DrawFilledRect(25.f, 25.f, 25.f, 25.f, 0x10FFFFFF);