summaryrefslogtreecommitdiffhomepage
path: root/proto-simconnect/ftnoir_protocol_sc.h
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2019-02-03 08:13:14 +0100
committerStanislaw Halik <sthalik@misaki.pl>2019-02-03 08:15:45 +0100
commit1beb7dfe8cd9a288893783862ce9f2e4a39239ab (patch)
treecd4afa0478b3029ba7ca1fbcf2ef28156a3ac739 /proto-simconnect/ftnoir_protocol_sc.h
parent3319f6bed166832020cbd4601b06ffcfac5c2d24 (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.h42
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