diff --git a/index.bs b/index.bs index b41dbd8..40890ec 100644 --- a/index.bs +++ b/index.bs @@ -19,6 +19,15 @@ Include MDN Panels: if possible Issue Tracking: DeviceOrientation Event Specification Issues Repository https://github.com/w3c/deviceorientation/issues Markup Shorthands: css no +
+urlPrefix: https://w3c.github.io/sensors/; spec: GENERIC-SENSOR + type: dfn + text: can provide readings flag; url: virtual-sensor-can-provide-readings-flag + text: virtual sensor mapping; url: virtual-sensor-mapping +urlPrefix: https://w3c.github.io/webdriver/; spec: WEBDRIVER2 + type: dfn + text: get a property; url: dfn-getting-properties +Conformance requirements {#conformance-requirements} ==================================================== @@ -320,12 +329,23 @@ The requestPermission(absolute To fire an orientation event given a event name (a string), window (a {{Window}}) and absolute (a boolean): + 1. Let orientation be null. + 1. Let topLevelTraversable be window's navigable's top-level traversable. + 1. Let virtualSensorType be "
relative-orientation
" if absolute is false, and "absolute-orientation
" otherwise.
+ 1. If topLevelTraversable's virtual sensor mapping contains virtualSensorType:
+ 1. Let virtualSensor be topLevelTraversable's virtual sensor mapping[virtualSensorType].
+ 1. If virtualSensor's can provide readings flag is true:
+ 1. Set orientation to the latest readings provided to virtualSensor with the "alpha
", "beta
", and "gamma
" keys.
+ 1. Otherwise:
+ 1. If absolute is false:
+ 1. Set orientation to the device's relative orientation in the tridimensional plane.
+ 1. Otherwise:
+ 1. Set orientation to the device's absolute orientation in the tridimensional plane.
+ 1. Let permissions be null.
1. If absolute is false:
- 1. Let orientation be the device's relative orientation in the tridimensional plane.
- 1. Let permissions be « "accelerometer", "gyroscope" ».
+ 1. Set permissions to « "accelerometer", "gyroscope" ».
1. Otherwise:
- 1. Let orientation be the device's absolute orientation in the tridimensional plane.
- 1. Let permissions be « "accelerometer", "gyroscope", "magnetometer" ».
+ 1. Set permissions to « "accelerometer", "gyroscope", "magnetometer" ».
1. Let environment be window's relevant settings object.
1. Run these steps in parallel:
1. For each permission name in permissions:
@@ -344,6 +364,8 @@ To fire an orientation event given a event name (a string)
A significant change in orientation indicates a difference in orientation values compared to the previous ones that warrants the firing of a deviceorientation
or deviceorientationabsolute
event. The process of determining whether a significant change in orientation has occurred is implementation-defined, though a maximum threshold for change of 1 degree is recommended. Implementations may also consider that it has occurred if they have reason to believe that the page does not have sufficiently fresh data.
+Note: Implementations must take [[#automation]] into account to determine whether a significant change in orientation has occurred, so that a virtual sensor reading update causes it to be assessed.
+
accelerometer
", "gyroscope
" »:
- 1. If document is not allowed to use the policy-controlled feature named policy, return.
+ 1. If document is not allowed to use the policy-controlled feature named policy, return.
+ 1. Let topLevelTraversable be window's navigable's top-level traversable.
+ 1. Let platformLinearAcceleration be null.
+ 1. If topLevelTraversable's virtual sensor mapping contains "linear-acceleration
":
+ 1. Let virtualSensor be topLevelTraversable's virtual sensor mapping["linear-acceleration
"].
+ 1. If virtualSensor's can provide readings flag is true, then set platformLinearAcceleration to the latest readings provided to virtualSensor.
+ 1. Otherwise, if the implementation is able to provide linear acceleration:
+ 1. Set platformLinearAcceleration to the device's linear acceleration along the X, Y and Z axes.
1. Let acceleration be null.
+ 1. If platformLinearAcceleration is not null:
+ 1. Set acceleration to a new {{DeviceMotionEventAcceleration}} created in window's realm.
+ 1. Set acceleration's x axis acceleration to platformLinearAcceleration's value along the X axis, or null if it cannot be provided.
+ 1. If acceleration's x axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
+ 1. Set acceleration's y axis acceleration to platformLinearAcceleration's value along the Y axis, or null if it cannot be provided.
+ 1. If acceleration's y axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
+ 1. Set acceleration's z axis acceleration to platformLinearAcceleration's value along the Z axis, or null if it cannot be provided.
+ 1. If acceleration's z axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
+ 1. Let platformAccelerationIncludingGravity be null.
+ 1. If topLevelTraversable's virtual sensor mapping contains "accelerometer
":
+ 1. Let virtualSensor be topLevelTraversable's virtual sensor mapping["accelerometer
"].
+ 1. If virtualSensor's can provide readings flag is true, then set platformAccelerationIncludingGravity to the latest readings provided to virtualSensor.
+ 1. Otherwise, if the implementation is able to provide acceleration with gravity:
+ 1. Set platformAccelerationIncludingGravity to the device's linear acceleration along the X, Y and Z axes.
1. Let accelerationIncludingGravity be null.
+ 1. If platformAccelerationIncludingGravity is not null:
+ 1. Set accelerationIncludingGravity to a new {{DeviceMotionEventAcceleration}} created in window's realm.
+ 1. Set accelerationIncludingGravity's x axis acceleration to platformAccelerationIncludingGravity's value along the X axis, or null if it cannot be provided.
+ 1. If accelerationIncludingGravity's x axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
+ 1. Set accelerationIncludingGravity's y axis acceleration to platformAccelerationIncludingGravity's value along the Y axis, or null if it cannot be provided.
+ 1. If accelerationIncludingGravity's y axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
+ 1. Set accelerationIncludingGravity's z axis acceleration to platformAccelerationIncludingGravity's value along the Z axis, or null if it cannot be provided.
+ 1. If accelerationIncludingGravity's z axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
+ 1. Let platformRotationRate be null.
+ 1. If topLevelTraversable's virtual sensor mapping contains "gyroscope
":
+ 1. Let virtualSensor be topLevelTraversable's virtual sensor mapping["gyroscope
"].
+ 1. If virtualSensor's can provide readings flag is true, then set platformRotationRate to the latest readings provided to virtualSensor.
+ 1. Otherwise, if the implementation is able to provide rotation rate:
+ 1. Set platformRotationRate to the device's rotation rate about the X, Y and Z axes.
1. Let rotationRate be null.
+ 1. If platformRotationRate is not null:
+ 1. Set rotationRate to a new {{DeviceMotionEventRotationRate}} created in window's realm.
+ 1. Set rotationRate's x axis rotation rate to platformRotationRate's value about the X axis, or null if it cannot be provided.
+ 1. If rotationRate's x axis rotation rate is not null, limit its precision to no more than 0.1 deg/s.
+ 1. Set rotationRate's y axis rotation rate to platformRotationRate's value about the Y axis, or null if it cannot be provided.
+ 1. If rotationRate's y axis rotation rate is not null, limit its precision to no more than 0.1 deg/s.
+ 1. Set rotationRate's z axis rotation rate to platformRotationRate's value about the Z axis, or null if it cannot be provided.
+ 1. If rotationRate's z axis rotation rate is not null, limit its precision to no more than 0.1 deg/s.
1. Let environment be window's relevant settings object.
1. Run these steps in parallel:
1. For each permission name in « "accelerometer", "gyroscope" »:
1. Let state be the result of getting the current permission state with permission name and environment.
1. If state is not "granted", return.
1. Queue a global task on the device motion and orientation task source given window to run the following steps:
- 1. If the implementation is able to provide linear acceleration:
- 1. Set acceleration to a new {{DeviceMotionEventAcceleration}} created in window's realm.
- 1. Set acceleration's x axis acceleration to the device's linear acceleration along the X axis, or null if it cannot be provided.
- 1. If acceleration's x axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
- 1. Set acceleration's y axis acceleration to the device's linear acceleration along the Y axis, or null if it cannot be provided.
- 1. If acceleration's y axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
- 1. Set acceleration's z axis acceleration to the device's linear acceleration along the Z axis, or null if it cannot be provided.
- 1. If acceleration's z axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
- 1. If the implementation is able to provide acceleration with gravity:
- 1. Set accelerationIncludingGravity to a new {{DeviceMotionEventAcceleration}} created in window's realm.
- 1. Set accelerationIncludingGravity's x axis acceleration to the device's acceleration with gravity along the X axis, or null if it cannot be provided.
- 1. If accelerationIncludingGravity's x axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
- 1. Set accelerationIncludingGravity's y axis acceleration to the device's acceleration with gravity along the Y axis, or null if it cannot be provided.
- 1. If accelerationIncludingGravity's y axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
- 1. Set accelerationIncludingGravity's z axis acceleration to the device's acceleration with gravity along the Z axis, or null if it cannot be provided.
- 1. If accelerationIncludingGravity's z axis acceleration is not null, limit its precision to no more than 0.1 m/s2.
- 1. If the implementation is able to provide rotation rate:
- 1. Set rotationRate to a new {{DeviceMotionEventRotationRate}} created in window's realm.
- 1. Set rotationRate's x axis rotation rate to the device's rotation rate about the X axis, or null if it cannot be provided.
- 1. If rotationRate's x axis rotation rate is not null, limit its precision to no more than 0.1 deg/s.
- 1. Set rotationRate's y axis rotation rate to the device's rotation rate about the Y axis, or null if it cannot be provided.
- 1. If rotationRate's y axis rotation rate is not null, limit its precision to no more than 0.1 deg/s.
- 1. Set rotationRate's z axis rotation rate to the device's rotation rate about the Z axis, or null if it cannot be provided.
- 1. If rotationRate's z axis rotation rate is not null, limit its precision to no more than 0.1 deg/s.
1. Fire an event named devicemotion
at window, using {{DeviceMotionEvent}}, with the {{DeviceMotionEvent/acceleration}} attribute initialized to acceleration, the {{DeviceMotionEvent/accelerationIncludingGravity}} attribute initialized to accelerationIncludingGravity, the {{DeviceMotionEvent/rotationRate}} attribute initialized to rotationRate, and the {{DeviceMotionEvent/interval}} attribute initialized to interval.
deviceorientation
event is built upon virtual sensors that represent accelerometers, gyroscopes and, optionally, magnetometers.
+
+Orientation data retrieved from the platform by the user agent comes from accelerometers, gyroscopes and, optionally, magnetometers. Contrary to motion data, however, these lower-level readings must be transformed into Euler angles in the formation described in [[#device-orientation-model]]. Furthermore, the platform might provide extra APIs to the user agent that already perform some of those conversions from raw acceleration and rotation data.
+
+Therefore, instead of requiring implementations (and automation users) to provide orientation readings via lower-level virtual sensors which use different units of measurement, this specification defines extra virtual sensor types for relative and orientation data in the format used by this specification.
+
+### Parse orientation reading data algorithm ### {#parse-orientation-data-reading-algorithm}
+
+alpha
".
+ 1. If alpha is not a {{Number}}, or its value is NaN, +∞, or −∞, return undefined.
+ 1. If alpha is not in the range [0, 360), then return undefined.
+ 1. Let beta be the result of invoking get a property from parameters with "beta
".
+ 1. If beta is not a {{Number}}, or its value is NaN, +∞, or −∞, return undefined.
+ 1. If beta is not in the range [-180, 180), then return undefined.
+ 1. Let gamma be the result of invoking get a property from parameters with "gamma
".
+ 1. If gamma is not a {{Number}}, or its value is NaN, +∞, or −∞, return undefined.
+ 1. If gamma is not in the range [-90, 90), then return undefined.
+ 1. Let reading be a new map.
+ 1. Set reading["alpha
"] to alpha.
+ 1. Set reading["beta
"] to beta.
+ 1. Set reading["gamma
"] to gamma.
+ 1. Return reading.
+
+Note: reading is defined as a map in the algorithm above to prevent a dependency on the sensor reading concept from the [[GENERIC-SENSOR]] specification. They should be interchangeable for the purposes of the algorithm above.
+
+absolute-orientation
"
+: value
+:: A virtual sensor metadata whose reading parsing algorithm is parse orientation data reading.
+
+### The "relative-orientation" virtual sensor type ### {#relative-orientation-virtual-sensors}
+
+The per-type virtual sensor metadata map must have the following entry:
+:
+: key
+:: "relative-orientation
"
+: value
+:: A virtual sensor metadata whose reading parsing algorithm is parse orientation data reading.
+
+Device Motion Automation {#device-motion-automation}
+------------------------
+
+The motion data retrieved from the platform by the user agent comes from accelerometers and gyroscopes. This specification defines certain per-type virtual sensor metadata entries that are shared with the [[ACCELEROMETER]] and [[GYROSCOPE]] specifications.
+
+Accelerometer virtual sensors are used to provide acceleration with gravity data to the platform. Linear Acceleration virtual sensors are used to provide linear acceleration data to the platform. Gyroscope virtual sensors are used to provide rotation rate data to the platform.
+
+### The "accelerometer" virtual sensor type ### {#accelerometer-virtual-sensors}
+
+The per-type virtual sensor metadata map must have the following entry:
+
+: key
+:: "accelerometer
"
+: value
+:: A virtual sensor metadata whose reading parsing algorithm is parse xyz reading.
+
+### The "linear-acceleration" virtual sensor type ### {#linear-acceleration-virtual-sensors}
+
+The per-type virtual sensor metadata map must have the following entry:
+
+: key
+:: "linear-acceleration
"
+: value
+:: A virtual sensor metadata whose reading parsing algorithm is parse xyz reading.
+
+### The "gyroscope" virtual sensor type ### {#gyroscope-virtual-sensors}
+
+The per-type virtual sensor metadata map must have the following entry:
+
+: key
+:: "gyroscope
"
+: value
+:: A virtual sensor metadata whose reading parsing algorithm is parse xyz reading.
+