knx stack (TP, IP and RF) for arduino and linux, Can be configured with ETS
Go to file
2024-01-31 07:13:55 +01: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 Update conf.py 2023-09-09 21:31:37 +02:00
examples fix build pipeline errors 2024-01-30 10:49:26 +01:00
src Update for New Uninitialized-Handling 2024-01-24 21:54:08 +01:00
.clang-format add .clang-format, remove VS class diagramm 2019-07-15 21:23:19 +02:00
.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
.readthedocs.yaml Update .readthedocs.yaml 2023-09-09 21:16:48 +02:00
CMakeLists.txt fix knxPython build 2020-10-28 21:44:01 +01:00
library.properties Update library.properties 2020-06-19 21:57:46 +02:00
LICENSE Create LICENSE 2018-04-21 21:51:41 +02:00
platformio.ini add platformio file and fix compiling without IP 2020-05-08 01:50:50 +02:00
README.md replace deprecated CreateKnxProd link with Kaenx-Creator 2024-01-23 20:22:31 +01: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 the Kaenx-Creator 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.