Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1168)

Unified Diff: content/browser/device_orientation/data_fetcher_impl_android.h

Issue 18572014: Implement Android shared memory data fetcher for Device Motion. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@renderer-sync-12June-tryASYNC-2-bis-tryRebase-6
Patch Set: fixed comments Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/browser/device_orientation/data_fetcher_impl_android.h
diff --git a/content/browser/device_orientation/data_fetcher_impl_android.h b/content/browser/device_orientation/data_fetcher_impl_android.h
index 4f431e0da117ab2b64d52c7b1c038dad3c86fba4..3bedfe850947d2a07a95b1a709a9b99386a9227d 100644
--- a/content/browser/device_orientation/data_fetcher_impl_android.h
+++ b/content/browser/device_orientation/data_fetcher_impl_android.h
@@ -8,11 +8,12 @@
#include "base/android/scoped_java_ref.h"
#include "base/memory/scoped_ptr.h"
#include "base/synchronization/lock.h"
-#include "content/browser/device_orientation/data_fetcher.h"
#include "content/browser/device_orientation/device_data.h"
+#include "content/common/device_motion_hardware_buffer.h"
-namespace content {
+template<typename T> struct DefaultSingletonTraits;
+namespace content {
class Orientation;
// Android implementation of DeviceOrientation API.
@@ -23,16 +24,15 @@ class Orientation;
// previous value if any). Chrome calls GetDeviceData() which reads the most
// recent value. Repeated calls to GetDeviceData() will return the same value.
-class DataFetcherImplAndroid : public DataFetcher {
+// TODO(timvolodine): Simplify this class and remove GetDeviceData() method,
+// once Device Orientation switches to shared memory implementation.
bulach 2013/07/12 16:07:43 thanks! just as an idea for the follow up: this cl
timvolodine 2013/07/12 17:43:56 ack, good idea.
+class DataFetcherImplAndroid {
public:
- // Must be called at startup, before Create().
+ // Must be called at startup, before GetInstance().
static void Init(JNIEnv* env);
- // Factory function. We'll listen for events for the lifetime of this object.
- // Returns NULL on error.
- static DataFetcher* Create();
-
- virtual ~DataFetcherImplAndroid();
+ // Needs to be thread-safe, because accessed from different threads.
+ static DataFetcherImplAndroid* GetInstance();
// Called from Java via JNI.
void GotOrientation(JNIEnv*, jobject,
@@ -44,21 +44,36 @@ class DataFetcherImplAndroid : public DataFetcher {
void GotRotationRate(JNIEnv*, jobject,
double alpha, double beta, double gamma);
- // Implementation of DataFetcher.
- virtual const DeviceData* GetDeviceData(DeviceData::Type type) OVERRIDE;
+ const DeviceData* GetDeviceData(DeviceData::Type type) OVERRIDE;
- private:
+ bool Start(DeviceData::Type event_type);
+ void Stop(DeviceData::Type event_type);
+
+ // Shared memory related methods.
+ bool StartFetchingDeviceMotionData(DeviceMotionHardwareBuffer* buffer);
+ void StopFetchingDeviceMotionData();
+
+ protected:
DataFetcherImplAndroid();
- const Orientation* GetOrientation();
+ virtual ~DataFetcherImplAndroid();
- // Wrappers for JNI methods.
- // TODO(timvolodine): move the DeviceData::Type enum to the service class
- // once it is implemented.
- bool Start(DeviceData::Type event_type, int rate_in_milliseconds);
- void Stop(DeviceData::Type event_type);
+ int GetNumberActiveDeviceMotionSensors();
+
+ private:
+ friend struct DefaultSingletonTraits<DataFetcherImplAndroid>;
+
+ const Orientation* GetOrientation();
- virtual int GetNumberActiveDeviceMotionSensors();
+ void CheckBufferReadyToRead();
+ void SetBufferReadyStatus(bool ready);
+ void ClearInternalBuffers();
+ enum {
+ RECEIVED_MOTION_DATA_ACCELERATION = 0,
+ RECEIVED_MOTION_DATA_ACCELERATION_INCL_GRAVITY = 1,
+ RECEIVED_MOTION_DATA_ROTATION_RATE = 2,
+ RECEIVED_MOTION_DATA_MAX = 3,
+ };
// Value returned by GetDeviceData.
scoped_refptr<Orientation> current_orientation_;
@@ -68,6 +83,10 @@ class DataFetcherImplAndroid : public DataFetcher {
// The Java provider of orientation info.
base::android::ScopedJavaGlobalRef<jobject> device_orientation_;
+ int number_active_device_motion_sensors_;
+ int received_motion_data_[RECEIVED_MOTION_DATA_MAX];
+ DeviceMotionHardwareBuffer* device_motion_buffer_;
+ bool is_buffer_ready_;
DISALLOW_COPY_AND_ASSIGN(DataFetcherImplAndroid);
};

Powered by Google App Engine
This is Rietveld 408576698