Neopixelbus Light ================= .. seo:: :description: Instructions for setting up Neopixel addressable lights. :image: color_lens.png The ``neopixelbus`` light platform allows you to create RGB lights in ESPHome for a individually addressable lights like NeoPixel or WS2812. It is very similar to the :doc:`fastled` platform. in fact most addressable lights are supported through both light platforms. The difference is that they use different libraries: While the fastled platform uses the `FastLED `__ library, this integration uses the `NeoPixelBus `__ library internally. .. code-block:: yaml # Example configuration entry light: - platform: neopixelbus type: GRB pin: GPIO23 num_leds: 60 name: "NeoPixel Light" Configuration variables: ------------------------ **Base Options:** - **name** (**Required**, string): The name of the light. - **gamma_correct** (*Optional*, float): The `gamma correction factor `__ for the light. Defaults to ``2.8``. - **id** (*Optional*, :ref:`config-id`): Manually specify the ID used for code generation. - **color_correct** (*Optional*, list of percentages): The color correction for each channel. This denotes the maximum brightness of the red, green, blue[, white] channel. Defaults to ``color_correct: [100%, 100%, 100%]``. - **default_transition_length** (*Optional*, :ref:`config-time`): The length of the transition if no transition parameter is provided by Home Assistant. Defaults to ``1s``. - **power_supply** (*Optional*, :ref:`config-id`): The :doc:`/components/power_supply` to connect to this light. When the light is turned on, the power supply will automatically be switched on too. - **effects** (*Optional*, list): A list of :ref:`light effects ` to use for this light. **Type Options:** - **type** (*Optional*, string): The type of light. This is used to specify if it is an RGBW or RGB light and in which order the colors are. Defaults to ``GRB``. Change this if you have lights with white value and/or the colors are in the wrong order. - **variant** (*Optional*, string): The chipset variant. You can read more about these `here `__ (some of the info on that page is not entirely correct). One of these values: - ``800KBPS`` (default) - ``400KBPS`` - ``WS2812X`` - ``SK6812`` - ``WS2813`` (same as ``WS2812X``) - ``WS2812`` (same as ``800KBPS``) - ``LC8812`` (same as ``SK6812``) - **method** (*Optional*, string): The method to transmit the data with. You can read more about these here: `ESP32 `__, `ESP8266 `__ - ``ESP8266_DMA`` (default for ESP8266, only on pin GPIO3) - ``ESP8266_UART0`` (only on pin GPIO1) - ``ESP8266_UART1`` (only on pin GPIO3) - ``ESP8266_ASYNC_UART0`` (only on pin GPIO1) - ``ESP8266_ASYNC_UART1`` (only on pin GPIO3) - ``ESP32_I2S_0`` - ``ESP32_I2S_1`` (default for ESP32) - ``BIT_BANG`` (can flicker a bit) - **num_leds** (**Required**, int): The number of LEDs attached. **Pin Options:** Some chipsets have two data pins to connect, others only have one. If you have one line, only specify ``pin``, otherwise specify both ``clock_pin`` and ``data_pin``. - **pin** (**Required**, :ref:`config-pin`): The pin for the data line of the light. - **clock_pin** (**Required**, :ref:`config-pin`): The pin for the clock line of the light, for two-pin lights. - **data_pin** (**Required**, :ref:`config-pin`): The pin for the data line of the light, for two-pin lights. **Advanced Options:** - **internal** (*Optional*, boolean): Mark this component as internal. Internal components will not be exposed to the frontend (like Home Assistant). Only specifying an ``id`` without a ``name`` will implicitly set this to true. - If MQTT enabled, all other options from :ref:`MQTT Component `. See Also -------- - :doc:`/components/light/index` - :doc:`/components/light/fastled` - :doc:`/components/power_supply` - :apiref:`light/neo_pixel_light_output.h` - `NeoPixelBus library `__ - :ghedit:`Edit`