Illuminance changed

The Illuminance changed trigger fires after a light level reading changes. The morning sun shining into a bedroom, a desk lamp switching on, or clouds shading a patio all show up as illuminance changes. Use the threshold type to filter which changes matter to your automation.

The threshold type controls where the new reading must land for the trigger to fire. You can require the new value to be above a level, below a level, within a range, or outside a range. You can also select Any change to fire on any change at all.

Use Illuminance changed to log light trends, react when a room becomes noticeably brighter or darker, or coordinate shades and lighting based on ambient conditions.

Labs

Requires the Purpose-specific triggers and conditions Labs preview feature. Enable it at Settings > System > Labs.

Using this trigger from the user interface

If you prefer building automations visually, Home Assistant walks you through this trigger step by step. You pick what to watch, tweak a few options, and save. No YAML knowledge required.

To use Illuminance changed in an automation:

  1. Go to Settings > Automations & scenes.
  2. Open an existing automation, or select Create automation > Create new automation.
  3. In the When section, select Add trigger.
  4. Select what you want to monitor. Under By target (see Targets), pick the area your light sensor is in (like your living room or backyard). You can also select a device, a specific entity, or a label. When you target multiple entities (via area, label, or multiple entity selections), the trigger fires whenever any of them changes.
  5. From the triggers shown for that target, select Illuminance changed.
  6. Under Threshold type, configure what kind of change fires the trigger:
    • Select Any change to fire on any change, regardless of direction or new value.
    • Select Above or Below and enter a value to fire only when the new reading is above or below that value.
    • Select In range and enter a lower and upper bound to fire only when the new reading falls inside the range.
    • Select Outside range and enter a lower and upper bound to fire only when the new reading is outside the range.
    • For each option, you can enter a fixed value in lux, pick a sensor entity, or pick a number helper entity as the threshold.
      • If you don’t have a number helper, you can create one by selecting Create a new number helper.
  7. Select Save.

Options in the UI

Threshold type

Controls which changes fire the trigger:

  • Any change: fires on any change, regardless of direction or new value.
  • Above or Below (exclusive): fires only when the new reading is strictly above or below the threshold. A reading equal to the threshold does not fire the trigger.
  • In range (exclusive): fires only when the new reading is strictly between the two bounds. A reading equal to either bound does not fire the trigger.
  • Outside range (inclusive): fires when the new reading is at or below the lower bound, or at or above the upper bound. A reading equal to either bound fires the trigger.

For each mode you can enter a fixed value in lux or reference a sensor entity or a number helper entity.

Using this trigger in YAML

If you work directly in YAML, or you want to know exactly what Home Assistant does under the hood, this section has the technical reference. It lists the field names you use in YAML, their types, and which ones are required.

In YAML, Illuminance changed is referred to as illuminance.changed. A basic example looks like this:

TriggerA trigger is a set of values or conditions of a platform that are defined to cause an automation to run. [Learn more]
trigger: illuminance.changed
target:
  entity_id: sensor.living_room_illuminance
options:
  threshold:
    type: above
    value:
      number: 500

This fires whenever the living room illuminance sensor reading moves to a value above 500 lx. To fire on any change regardless of direction or value, use type: any and omit value.

To fire only when the new reading is within a comfortable reading range:

TriggerA trigger is a set of values or conditions of a platform that are defined to cause an automation to run. [Learn more]
trigger: illuminance.changed
target:
  entity_id:
    - sensor.living_room_illuminance
    - sensor.office_illuminance
options:
  threshold:
    type: between
    value_min:
      number: 300
    value_max:
      number: 750

This fires whenever any of the illuminance sensors changes to a value within the reading range (300 lx to 750 lx).

To use a number helper as a dynamic threshold that you can adjust without editing the automation:

TriggerA trigger is a set of values or conditions of a platform that are defined to cause an automation to run. [Learn more]
trigger: illuminance.changed
target:
  entity_id: sensor.living_room_illuminance
options:
  threshold:
    type: above
    value:
      entity: input_number.brightness_alert_threshold

Options in YAML

YAML sometimes provides additional options for more complex use cases that are not available through the UI.

threshold map Required

A mapping that defines which kind of change fires the trigger:

  • type: any: Fires on any illuminance change (no additional keys needed).
  • type: above (exclusive): Sets a minimum. Fires when the reading is strictly above value. A reading equal to value does not fire the trigger. Provide value with a number key (for a literal value in lux) or an entity key (for an input_number, number, or sensor entity).
  • type: below (exclusive): Sets a maximum. Fires when the reading is strictly below value. A reading equal to value does not fire the trigger. Provide value with a number key (for a literal value in lux) or an entity key (for an input_number, number, or sensor entity).
  • type: between (exclusive): Defines a range. Fires when the reading is strictly between value_min and value_max. Readings equal to either bound do not fire the trigger. Provide value_min and value_max, each with a number key (for a literal value in lux) or an entity key (for an input_number, number, or sensor entity).
  • type: outside (inclusive): Defines an outside-range. Fires when the reading is at or below value_min, or at or above value_max. Readings equal to either bound fire the trigger. Provide value_min and value_max, each with a number key (for a literal value in lux) or an entity key (for an input_number, number, or sensor entity).

Targets of the trigger

This trigger requires a target. The target is the object that Home Assistant will watch. You can select a single entityAn entity represents a sensor, actor, or function in Home Assistant. Entities are used to monitor physical properties or to control other entities. An entity is usually part of a device or a service. [Learn more], a device, an area, a floor, or a label as a target, and Home Assistant will watch every matching illuminance entity behind that target.

  • Entity: one specific illuminance entity, such as illuminance.living_room.
  • Device: every illuminance entity that belongs to a device.
  • Area: every illuminance entity in a room or area.
  • Floor: every illuminance entity on a floor.
  • Label: every illuminance entity that shares a label.

You can also select different target types in one trigger. For example, you can add a specific entity and an area as targets in the same trigger to monitor both of them at once.

Good to know

  • Illuminance is measured in lux (lx). For reference: a brightly lit office is around 500 lx, indirect daylight is several thousand lx, and direct sunlight can exceed 100,000 lx.
  • The threshold type controls both the direction and the landing zone of the change. Use Above or Below to filter by direction, In range to fire only when the new value is inside a range, and Outside range to fire only when it escapes a range.
  • Use Any change to fire on every change regardless of direction or where the new value lands.
  • To react only when an illuminance reading first crosses a specific level, use Illuminance crossed threshold instead.
  • The trigger works with sensors that have the illuminance device class, and with number entities that use lux as the unit of measurement.

Try it yourself

Ready to test this? Go to Settings > Automations & scenes, create a new automation, and add this trigger. Save the automation, then change the state of the targeted entity to watch the trigger fire on your actual entitiesAn entity represents a sensor, actor, or function in Home Assistant. Entities are used to monitor physical properties or to control other entities. An entity is usually part of a device or a service. [Learn more].

More examples

Real scenarios where this trigger fires in automations and scripts. Copy any example and adapt it to your setup.

Tip

You don’t need to edit YAML to use these examples. Copy a YAML snippet from this page, open the automation editor in Home Assistant, and press Ctrl+V (or Cmd+V on Mac). Home Assistant automatically converts the pasted YAML into the visual editor format, whether it’s a full automation, a single trigger, a condition, or an action.

Automation: close the blinds when the patio gets too bright

When the patio illuminance sensor reports a sudden increase in brightness, close the patio blinds to keep direct sunlight off the furniture.

  • Trigger: Illuminance changed
    • Target: Patio illuminance sensor
    • Threshold type: Above 30000 lx
  • Action: Close cover
    • Target: cover.patio_blinds
YAML example for closing patio blinds on bright sunlight
AutomationAutomations in Home Assistant allow you to automatically respond to things that happen in and around your home. [Learn more]
alias: "Close patio blinds in bright sunlight"
triggers:
  - trigger: illuminance.changed
    target:
      entity_id: sensor.patio_illuminance
    options:
      threshold:
        type: above
        value:
          number: 30000
actions:
  - action: cover.close_cover
    target:
      entity_id: cover.patio_blinds

Still stuck?

The Home Assistant community is quick to help: join Discord for real-time chat, post on the community forum with the trigger you’re using and what you expected to happen, or share on our subreddit /r/homeassistant.

Tip

AI assistants like ChatGPT or Claude can also explain triggers or suggest the right one when you describe what you want in plain language.

Related triggers

These triggers work well alongside this one: