Index: content/browser/device_sensors/sensor_manager_android.h |
diff --git a/content/browser/device_sensors/sensor_manager_android.h b/content/browser/device_sensors/sensor_manager_android.h |
index f2a552ecf5c67181ba07d64a223a108aa605b74f..b8e90d86434fdd2e62205a35bb3c8e2c8f6633c8 100644 |
--- a/content/browser/device_sensors/sensor_manager_android.h |
+++ b/content/browser/device_sensors/sensor_manager_android.h |
@@ -9,6 +9,7 @@ |
#include "base/memory/scoped_ptr.h" |
#include "base/synchronization/lock.h" |
#include "content/common/content_export.h" |
+#include "content/common/device_sensors/device_light_hardware_buffer.h" |
#include "content/common/device_sensors/device_motion_hardware_buffer.h" |
#include "content/common/device_sensors/device_orientation_hardware_buffer.h" |
@@ -16,7 +17,7 @@ template<typename T> struct DefaultSingletonTraits; |
namespace content { |
-// Android implementation of Device Orientation API. |
+// Android implementation of Device {Motion|Orientation|Light} API. |
// |
// Android's SensorManager has a push API, so when Got*() methods are called |
// by the system the browser process puts the received data into a shared |
@@ -30,6 +31,7 @@ class CONTENT_EXPORT SensorManagerAndroid { |
static SensorManagerAndroid* GetInstance(); |
// Called from Java via JNI. |
+ void GotLight(JNIEnv*, jobject, double value); |
void GotOrientation(JNIEnv*, jobject, |
double alpha, double beta, double gamma); |
void GotAcceleration(JNIEnv*, jobject, |
@@ -40,6 +42,9 @@ class CONTENT_EXPORT SensorManagerAndroid { |
double alpha, double beta, double gamma); |
// Shared memory related methods. |
+ bool StartFetchingDeviceLightData(DeviceLightHardwareBuffer* buffer); |
+ void StopFetchingDeviceLightData(); |
+ |
bool StartFetchingDeviceMotionData(DeviceMotionHardwareBuffer* buffer); |
void StopFetchingDeviceMotionData(); |
@@ -49,11 +54,12 @@ class CONTENT_EXPORT SensorManagerAndroid { |
protected: |
enum EventType { |
- // These constants should match DEVICE_ORIENTATION and DEVICE_MOTION |
- // constants in content/public/android/java/src/org/chromium/content/ |
- // browser/DeviceMotionAndOrientation.java |
+ // These constants should match DEVICE_ORIENTATION, DEVICE_MOTION and |
+ // DEVICE_LIGHT constants in content/public/android/java/src/org/ |
+ // chromium/content/browser/DeviceSensors.java |
kTypeOrientation = 0, |
- kTypeMotion = 1 |
+ kTypeMotion = 1, |
+ kTypeLight = 2 |
}; |
SensorManagerAndroid(); |
@@ -73,21 +79,26 @@ class CONTENT_EXPORT SensorManagerAndroid { |
RECEIVED_MOTION_DATA_MAX = 3, |
}; |
+ void SetLightBufferValue(double lux); |
+ |
void CheckMotionBufferReadyToRead(); |
void SetMotionBufferReadyStatus(bool ready); |
void ClearInternalMotionBuffers(); |
void SetOrientationBufferReadyStatus(bool ready); |
- // The Java provider of orientation info. |
- base::android::ScopedJavaGlobalRef<jobject> device_orientation_; |
+ // The Java provider of sensors info. |
+ base::android::ScopedJavaGlobalRef<jobject> device_sensors_; |
int number_active_device_motion_sensors_; |
int received_motion_data_[RECEIVED_MOTION_DATA_MAX]; |
+ DeviceLightHardwareBuffer* device_light_buffer_; |
DeviceMotionHardwareBuffer* device_motion_buffer_; |
DeviceOrientationHardwareBuffer* device_orientation_buffer_; |
+ bool is_light_buffer_ready_; |
bool is_motion_buffer_ready_; |
bool is_orientation_buffer_ready_; |
+ base::Lock light_buffer_lock_; |
base::Lock motion_buffer_lock_; |
base::Lock orientation_buffer_lock_; |