summaryrefslogtreecommitdiffstats
path: root/src/plugins/sensors/winrt/winrtorientationsensor.cpp
diff options
context:
space:
mode:
authorLiang Qi <liang.qi@theqtcompany.com>2016-02-19 16:09:02 +0100
committerLiang Qi <liang.qi@theqtcompany.com>2016-02-19 19:27:43 +0100
commit5cf1a2f7f4ac4e71b085ef53ff5a05c4676f7ce2 (patch)
treeeff94d6fba0053177b0f6dac2e93b9ce27cbf294 /src/plugins/sensors/winrt/winrtorientationsensor.cpp
parent5e8d2b4e266916761a26905f0930add305c308cf (diff)
parentfbaca62cd0a7309f04bf82101c8e20dbbf423192 (diff)
Merge remote-tracking branch 'origin/5.6' into 5.7v5.7.0-alpha1
Conflicts: .qmake.conf src/sensors/doc/src/compatmap.qdoc Change-Id: I4049bc3c335a8a9db5c935032207d0bcfba78480
Diffstat (limited to 'src/plugins/sensors/winrt/winrtorientationsensor.cpp')
-rw-r--r--src/plugins/sensors/winrt/winrtorientationsensor.cpp42
1 files changed, 25 insertions, 17 deletions
diff --git a/src/plugins/sensors/winrt/winrtorientationsensor.cpp b/src/plugins/sensors/winrt/winrtorientationsensor.cpp
index a40dbb9d..c679d925 100644
--- a/src/plugins/sensors/winrt/winrtorientationsensor.cpp
+++ b/src/plugins/sensors/winrt/winrtorientationsensor.cpp
@@ -38,9 +38,9 @@
#include "winrtcommon.h"
#include <QtSensors/QOrientationSensor>
+#include <private/qeventdispatcher_winrt_p.h>
-QT_USE_NAMESPACE
-
+#include <functional>
#include <wrl.h>
#include <windows.devices.sensors.h>
using namespace Microsoft::WRL;
@@ -119,20 +119,24 @@ WinRtOrientationSensor::WinRtOrientationSensor(QSensor *sensor)
: QSensorBackend(sensor), d_ptr(new WinRtOrientationSensorPrivate(this))
{
Q_D(WinRtOrientationSensor);
- HStringReference classId(RuntimeClass_Windows_Devices_Sensors_SimpleOrientationSensor);
- ComPtr<ISimpleOrientationSensorStatics> factory;
- HRESULT hr = RoGetActivationFactory(classId.Get(), IID_PPV_ARGS(&factory));
- if (FAILED(hr)) {
- qCWarning(lcWinRtSensors) << "Unable to initialize orientation sensor factory."
- << qt_error_string(hr);
- sensorError(hr);
- return;
- }
+ HRESULT hr = QEventDispatcherWinRT::runOnXamlThread([d]() {
+ HStringReference classId(RuntimeClass_Windows_Devices_Sensors_SimpleOrientationSensor);
+ ComPtr<ISimpleOrientationSensorStatics> factory;
+ HRESULT hr = RoGetActivationFactory(classId.Get(), IID_PPV_ARGS(&factory));
+ if (FAILED(hr)) {
+ qCWarning(lcWinRtSensors) << "Unable to initialize orientation sensor factory."
+ << qt_error_string(hr);
+ return hr;
+ }
- hr = factory->GetDefault(&d->sensor);
+ hr = factory->GetDefault(&d->sensor);
+ if (FAILED(hr)) {
+ qCWarning(lcWinRtSensors) << "Unable to get default orientation sensor."
+ << qt_error_string(hr);
+ }
+ return hr;
+ });
if (FAILED(hr) || !d->sensor) {
- qCWarning(lcWinRtSensors) << "Unable to get default orientation sensor."
- << qt_error_string(hr);
sensorError(hr);
return;
}
@@ -152,9 +156,11 @@ void WinRtOrientationSensor::start()
if (d->token.value)
return;
- ComPtr<SimpleOrientationReadingHandler> callback =
+ HRESULT hr = QEventDispatcherWinRT::runOnXamlThread([d]() {
+ ComPtr<SimpleOrientationReadingHandler> callback =
Callback<SimpleOrientationReadingHandler>(d, &WinRtOrientationSensorPrivate::readingChanged);
- HRESULT hr = d->sensor->add_OrientationChanged(callback.Get(), &d->token);
+ return d->sensor->add_OrientationChanged(callback.Get(), &d->token);
+ });
if (FAILED(hr)) {
qCWarning(lcWinRtSensors) << "Unable to attach to reading changed event."
<< qt_error_string(hr);
@@ -171,7 +177,9 @@ void WinRtOrientationSensor::stop()
if (!d->token.value)
return;
- HRESULT hr = d->sensor->remove_OrientationChanged(d->token);
+ HRESULT hr = QEventDispatcherWinRT::runOnXamlThread([d]() {
+ return d->sensor->remove_OrientationChanged(d->token);
+ });
if (FAILED(hr)) {
qCWarning(lcWinRtSensors) << "Unable to detach from reading changed event."
<< qt_error_string(hr);