knx stack (TP, IP and RF) for arduino and linux, Can be configured with ETS
Go to file
2023-08-24 10:43:21 +02:00
.github/workflows Update CodeQL (#219) 2022-10-22 14:18:55 +02:00
.vscode 32bit eeprom size (#230) 2023-02-13 21:39:30 +01:00
doc Add coupler support (#79) 2020-09-06 21:41:34 +02:00
examples H8I8O Example (#210) 2022-08-15 11:27:57 +02:00
src Improved float16ToPayload correction 2023-08-24 10:43:21 +02:00
.clang-format
.gitattributes opt-out global KNX, ability to DIY construct knx object, minor cleanups (#121) 2021-02-05 15:57:45 +01:00
.gitignore opt-out global KNX, ability to DIY construct knx object, minor cleanups (#121) 2021-02-05 15:57:45 +01:00
CMakeLists.txt fix knxPython build 2020-10-28 21:44:01 +01:00
library.properties
LICENSE
platformio.ini
README.md Update README.md 2022-08-15 11:31:29 +02:00

knx

This projects provides a knx-device stack for arduino (ESP8266, ESP32, SAMD21, RP2040, STM32), CC1310 and linux. (more are quite easy to add) It implements most of System-B specification and can be configured with ETS. The necessary knxprod-files can be generated with my CreateKnxProd tool.

For ESP8266 and ESP32 WifiManager is used to configure wifi.

Don't forget to reset ESP8266 manually (disconnect power) after flashing. The reboot doen't work during configuration with ETS otherwise.

Generated documentation can be found here.

Stack configuration possibilities

Specify prog button GPIO other then GPIO0:

knx.buttonPin(3); // Use GPIO3 Pin

Specify a LED GPIO for programming mode other then the LED_BUILTIN:

knx.ledPin(5);

Use a custom function instead of a LED connected to GPIO to indicate the programming mode:

#include <Arduino.h>
#include <Adafruit_NeoPixel.h>
#include <knx.h>
// create a pixel strand with 1 pixel on PIN_NEOPIXEL
Adafruit_NeoPixel pixels(1, PIN_NEOPIXEL);

void progLedOff()
{
  pixels.clear();
  pixels.show();
}

void progLedOn()
{
  pixels.setPixelColor(0, pixels.Color(20, 0, 0));
  pixels.show();
}

void main ()
{
 knx.setProgLedOffCallback(progLedOff);
 knx.setProgLedOnCallback(progLedOn);
 [...]
}

More configuration options can be found in the examples.