From 1beb7dfe8cd9a288893783862ce9f2e4a39239ab Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Sun, 3 Feb 2019 08:13:14 +0100 Subject: proto/simconnect: fix activation context again Issue: #804 --- proto-simconnect/ftnoir_protocol_sc.h | 42 +++++++++++++++++------------------ 1 file changed, 20 insertions(+), 22 deletions(-) (limited to 'proto-simconnect/ftnoir_protocol_sc.h') diff --git a/proto-simconnect/ftnoir_protocol_sc.h b/proto-simconnect/ftnoir_protocol_sc.h index 03f27917..aec43e57 100644 --- a/proto-simconnect/ftnoir_protocol_sc.h +++ b/proto-simconnect/ftnoir_protocol_sc.h @@ -42,26 +42,24 @@ public: ~simconnect() override; module_status initialize() override; void pose(const double* headpose) override; - void handle(); - QString game_name() override - { - return tr("FS2004/FSX"); - } + QString game_name() override; + void run() override; + private: + void handler(); + enum { SIMCONNECT_RECV_ID_EXCEPTION = 2, SIMCONNECT_RECV_ID_QUIT = 3, SIMCONNECT_RECV_ID_EVENT_FRAME = 7, }; - #pragma pack(push, 1) struct SIMCONNECT_RECV { DWORD dwSize; DWORD dwVersion; DWORD dwID; }; - #pragma pack(pop) typedef void (CALLBACK *DispatchProc)(SIMCONNECT_RECV*, DWORD, void*); @@ -71,8 +69,6 @@ private: typedef HRESULT (WINAPI *importSimConnect_CallDispatch)(HANDLE hSimConnect, DispatchProc pfcnDispatch, void * pContext); typedef HRESULT (WINAPI *importSimConnect_SubscribeToSystemEvent)(HANDLE hSimConnect, DWORD EventID, const char * SystemEventName); - void run() override; - std::atomic virtSCPosX {0}; std::atomic virtSCPosY {0}; std::atomic virtSCPosZ {0}; @@ -80,35 +76,37 @@ private: std::atomic virtSCRotY {0}; std::atomic virtSCRotZ {0}; - importSimConnect_Open simconnect_open; - importSimConnect_Close simconnect_close; - importSimConnect_CameraSetRelative6DOF simconnect_set6DOF; - importSimConnect_CallDispatch simconnect_calldispatch; - importSimConnect_SubscribeToSystemEvent simconnect_subscribetosystemevent; + importSimConnect_Open simconnect_open = nullptr; + importSimConnect_Close simconnect_close = nullptr; + importSimConnect_CameraSetRelative6DOF simconnect_set6DOF = nullptr; + importSimConnect_CallDispatch simconnect_calldispatch = nullptr; + importSimConnect_SubscribeToSystemEvent simconnect_subscribetosystemevent = nullptr; - HANDLE hSimConnect = nullptr; + HANDLE handle = nullptr; std::atomic reconnect = false; static void CALLBACK processNextSimconnectEvent(SIMCONNECT_RECV* pData, DWORD cbData, void *pContext); settings s; - QLibrary SCClientLib; + QLibrary library; }; -class SCControls: public IProtocolDialog +class simconnect_ui: public IProtocolDialog { Q_OBJECT + + Ui::UICSCControls ui; + settings s; + public: - SCControls(); + simconnect_ui(); void register_protocol(IProtocol *) override {} void unregister_protocol() override {} -private: - Ui::UICSCControls ui; - settings s; + private slots: void doOK(); void doCancel(); }; -class simconnectDll : public Metadata +class simconnect_metadata : public Metadata { Q_OBJECT -- cgit v1.2.3