dom / latest / ambientlightsensor.html /

AmbientLightSensor

Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.

The AmbientLightSensor interface of the Sensor APIs returns the current light level or illuminance of the ambient light around the hosting device.

To use this sensor, the user must grant permission to the 'ambient-light-sensor' device sensor through the Permissions API.

If a feature policy blocks use of a feature it is because your code is inconsistent with the policies set on your server. This is not something that would ever be shown to a user. The Feature-Policy HTTP header article contains implementation instructions.

EventTarget Sensor AmbientLightSensor

Constructor

AmbientLightSensor()

Creates a new AmbientLightSensor object.

Properties

AmbientLightSensor.illuminance

Returns the current light level in lux of the ambient light level around the hosting device.

Methods

AmbientLightSensor doesn't have own methods. However, it inherits methods from its parent interfaces, Sensor and EventTarget.

Events

AmbientLightSensor doesn't have own events. However, it inherits events from its parent interface, Sensor.

Example

if ( 'AmbientLightSensor' in window ) {
  const sensor = new AmbientLightSensor();
  sensor.addEventListener('reading', event => {
    console.log('Current light level:', sensor.illuminance);
  });
  sensor.addEventListener('error', event => {
    console.log(event.error.name, event.error.message);
  });
  sensor.start();
}

Specifications

Browser compatibility

Desktop Mobile
Chrome Edge Firefox Internet Explorer Opera Safari WebView Android Chrome Android Firefox for Android Opera Android Safari on IOS Samsung Internet
AmbientLightSensor
56
79
No
No
43
No
No
56
No
43
No
No
AmbientLightSensor
56
79
No
No
43
No
No
56
No
43
No
No
illuminance
56
In Chrome 79, this method stopped returning floats and returned integers to avoid fingerprinting.
79
No
No
43
In Opera 66, this method stopped returning floats and returned integers to avoid fingerprinting.
No
No
56
In Chrome for Android 79, this method stopped returning floats and returned integers to avoid fingerprinting.
No
43
In Opera for Android 57, this method stopped returning floats and returned integers to avoid fingerprinting.
No
No

© 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/AmbientLightSensor