Index: content/browser/device_orientation/sensor_manager_android.h |
diff --git a/content/browser/device_orientation/sensor_manager_android.h b/content/browser/device_orientation/sensor_manager_android.h |
index 6276065dc25d2a81199b9f6407f27439abf12963..717bb938e291173e71c7b290dd033dac84a5f442 100644 |
--- a/content/browser/device_orientation/sensor_manager_android.h |
+++ b/content/browser/device_orientation/sensor_manager_android.h |
@@ -2,13 +2,14 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#ifndef CHROME_BROWSER_DEVICE_ORIENTATION_SENSOR_MANAGER_ANDROID_H_ |
-#define CHROME_BROWSER_DEVICE_ORIENTATION_SENSOR_MANAGER_ANDROID_H_ |
+#ifndef CONTENT_BROWSER_DEVICE_ORIENTATION_SENSOR_MANAGER_ANDROID_H_ |
+#define CONTENT_BROWSER_DEVICE_ORIENTATION_SENSOR_MANAGER_ANDROID_H_ |
#include "base/android/scoped_java_ref.h" |
#include "base/memory/scoped_ptr.h" |
#include "base/synchronization/lock.h" |
#include "content/common/content_export.h" |
+#include "content/common/device_light/device_light_hardware_buffer.h" |
#include "content/common/device_orientation/device_motion_hardware_buffer.h" |
#include "content/common/device_orientation/device_orientation_hardware_buffer.h" |
@@ -30,6 +31,8 @@ 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 +43,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 +55,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/DeviceMotionAndOrientation.java |
kTypeOrientation = 0, |
- kTypeMotion = 1 |
+ kTypeMotion = 1, |
+ kTypeLight = 2 |
}; |
SensorManagerAndroid(); |
@@ -77,17 +84,23 @@ class CONTENT_EXPORT SensorManagerAndroid { |
void SetMotionBufferReadyStatus(bool ready); |
void ClearInternalMotionBuffers(); |
+ void SetLightBufferReadyStatus(bool ready); |
+ void ClearInternalLightBuffers(); |
+ |
void SetOrientationBufferReadyStatus(bool ready); |
// 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]; |
+ 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_; |
@@ -96,4 +109,4 @@ class CONTENT_EXPORT SensorManagerAndroid { |
} // namespace content |
-#endif // CHROME_BROWSER_DEVICE_ORIENTATION_SENSOR_MANAGER_ANDROID_H_ |
+#endif // CONTENT_BROWSER_DEVICE_ORIENTATION_SENSOR_MANAGER_ANDROID_H_ |