gpt4 book ai didi

c++ - 从 WPF 窗口内的托管 DLL 启动 WNDProc

转载 作者:太空宇宙 更新时间:2023-11-04 12:08:33 24 4
gpt4 key购买 nike

我在尝试让托管 DLL 与我的 WPF 应用程序一起工作时遇到了困难。这个想法是从 WPF MainWindow 的代码背后调用该函数(这样我可以获得窗口句柄)并传递它和另一个最终成为 wchar_t 类型指针的指针。

我可以调用 dll,但是 WNDProc 没有启动,我认为它与应用程序实例甚至句柄有关,但我无法确定。项目构建成功,只是没有运行 WNDProc。

该应用程序的想法是使用 WPF 并调用 c++ 来启动一个服务器实例,该实例调用 Windows 内置的远程协助 API。

这是我所拥有的:

#pragma once

#include "stdafx.h"
#include <winsock2.h>
#include <tchar.h>
#include "RDP.h"

#pragma warning(disable : 4996)
#pragma warning(disable : 4267)
#pragma comment(lib,"ws2_32.lib")

namespace RDPServerSession
{
RAS::SERVER* s = 0;
HWND MainWindow = 0;
HWND hL = 0;
HINSTANCE hAppInstance = 0;
wchar_t* password;

enum
{
MESSAGE_NOTIFY = WM_USER + 2,
};

public ref class Server
{
public:
void StartServer(System::IntPtr id, System::IntPtr handle)
{
password = reinterpret_cast<wchar_t*>(id.ToPointer());

WSADATA wData;
WSAStartup(MAKEWORD(2, 2), &wData);
CoInitializeEx(0,COINIT_APARTMENTTHREADED);
/*INITCOMMONCONTROLSEX icex = {0};
icex.dwICC = ICC_LISTVIEW_CLASSES | ICC_DATE_CLASSES | ICC_WIN95_CLASSES;
icex.dwSize = sizeof(icex);
InitCommonControlsEx(&icex);*/
//InitCommonControls();
//PrepareDoMatchTable();

hAppInstance = GetModuleHandle(NULL);

WNDCLASSEX wClass = {0};
wClass.cbSize = sizeof(wClass);

wClass.style = CS_DBLCLKS | CS_HREDRAW | CS_VREDRAW | CS_PARENTDC;
wClass.lpfnWndProc = (WNDPROC)Main_DP;
wClass.hInstance = hAppInstance;
wClass.hCursor = LoadCursor(0, IDC_ARROW);
wClass.hbrBackground = (HBRUSH) GetStockObject(WHITE_BRUSH);
wClass.lpszClassName = _T("CLASS");
RegisterClassEx(&wClass);

/*MainWindow = CreateWindowEx(0,
_T("CLASS"),
ttitle,
WS_OVERLAPPEDWINDOW | WS_CLIPSIBLINGS |
WS_CLIPCHILDREN, CW_USEDEFAULT, CW_USEDEFAULT,
500, 600, 0,LoadMenu(h,_T("MENU_1")), h, 0);*/

ShowWindow(MainWindow,SW_SHOW);

MSG msg;

while(GetMessage(&msg,0,0,0))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return;
}



static void StartS(HWND hh)
{
if (!s)
{
s = new RAS::SERVER;
int ty = 0,po = 0,col = 16;
bool dy = 0;

bool Rev = false;
if (GetKeyState(VK_CONTROL) >> 15)
Rev = true;



s->CreateVirtualChannel(L"test",true,CHANNEL_PRIORITY_MED);
s->Open();
s->SetWindowNotification(hh,MESSAGE_NOTIFY);

vector<int> pids;
vector<wstring> names;
vector<int> ST;
s->GetShareableApplications(pids,names,ST);

RAS::S_INVITATION* inv = s->Invite(0,password,L"group",3);
if (inv)
{
const wchar_t* password = inv->GetTicket().c_str();
}

return;
}
else
{
delete s;
s = 0;
}
}

static LRESULT CALLBACK Main_DP(HWND hh,UINT mm,WPARAM ww,LPARAM ll)
{
switch(mm)
{
case WM_COMMAND:
{
int LW = LOWORD(ww);
if (LW == 100)
StartS(hh);
return 0;
}

case WM_CLOSE:
{
if (s)
StartS(hh);
DestroyWindow(hh);
return 0;
}

case WM_DESTROY:
{
PostQuitMessage(0);
return 0;
}
}
return DefWindowProc(hh,mm,ww,ll);
}




void StopServer() { delete s; }
~Server() { }
};

对于为什么 Wndproc 不运行有什么想法或建议吗?

干杯。

最佳答案

窗口过程 Main_DP 与窗口类 CLASS 相关联。但是您不使用该类创建窗口(代码被注释掉),因此不使用窗口过程。

更新

您想处理现有主窗口的消息,但不能将新窗口类与现有窗口相关联。相反,您需要 subclass the window . (正如 Ben Voigt 所指出的,您不应使用 SetWindowLong 技术。)

一旦将窗口子类化,就不需要自己的消息循环了。只需返回 WPF 代码即可。 (请注意,可能无法可靠地用您自己的消息循环替换 WPF 的消息循环。它可能不仅仅是一个简单的 TranslateMessage/DispatchMessage。)

关于c++ - 从 WPF 窗口内的托管 DLL 启动 WNDProc,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10839675/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com