diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2019-02-03 08:13:14 +0100 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2019-02-03 08:15:45 +0100 |
commit | 1beb7dfe8cd9a288893783862ce9f2e4a39239ab (patch) | |
tree | cd4afa0478b3029ba7ca1fbcf2ef28156a3ac739 /proto-simconnect/ftnoir_protocol_sc.h | |
parent | 3319f6bed166832020cbd4601b06ffcfac5c2d24 (diff) |
proto/simconnect: fix activation context again
Issue: #804
Diffstat (limited to 'proto-simconnect/ftnoir_protocol_sc.h')
-rw-r--r-- | proto-simconnect/ftnoir_protocol_sc.h | 42 |
1 files changed, 20 insertions, 22 deletions
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<float> virtSCPosX {0}; std::atomic<float> virtSCPosY {0}; std::atomic<float> virtSCPosZ {0}; @@ -80,35 +76,37 @@ private: std::atomic<float> virtSCRotY {0}; std::atomic<float> 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<bool> 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 |