mirror of
https://github.com/thelsing/knx.git
synced 2025-01-21 00:05:43 +01:00
f169e20f2f
* Refactored the knx_facade a bit to make the auto-building of the global knx object and the buttonUp() ISR function opt-in. Also added the ability to quite easily attach another serial (in this case tested with Serial2 of an ESP32). * Added visual studio code temp files to .gitignore * Fix for missing build flag for WifiManager in ESP32_ip demo * Added example in which we DIY build the KNX object and use ESP32's second UART to connect so that you can debug with the first one that's connected to USB. * Minor platform cleanups to remove compilation warnings. * ESP32 can't handle the defaulted 8192 byte EPROM. Next to that I needed to begin() the eprom lib in my setup() to get it to work and that requires knowing how much memory KNX will use. This fix makes the default more conservative and moves it's definition to the .h file so that other files can always use it as well. * After comments from thelsing, inverted the logic. The default global knx object is now opt-out by defining KNX_NO_AUTOMATIC_GLOBAL_INSTANCE. See the knx-demo-diy project for an example. Minor syntactic cleanups. * Removed hardwareserial from facade (detail which was not needed) Placed facade constructors together Minor syntactic cleanup * Fixed knx-cc1310 where own button routine was calling now private internal knx facade variable. Renamed files in knx-demo-diy Minor syntactic stuff * Added gitattributes for binary knxprod files
139 lines
3.5 KiB
C++
139 lines
3.5 KiB
C++
#include <knx.h>
|
|
#include <knx/bau07B0.h>
|
|
|
|
#ifdef ARDUINO_ARCH_ESP8266
|
|
#include <WiFiManager.h>
|
|
#endif
|
|
|
|
// create named references for easy access to group objects
|
|
#define goCurrent knx.getGroupObject(1)
|
|
#define goMax knx.getGroupObject(2)
|
|
#define goMin knx.getGroupObject(3)
|
|
#define goReset knx.getGroupObject(4)
|
|
|
|
// If you don't want a global knx object, for example because you want
|
|
// to more finely control it's construction, this is an example
|
|
// of how to do so. Define KNX_NO_AUTOMATIC_GLOBAL_INSTANCE
|
|
// and then you can DIY a knx object as shown below. In this case we use
|
|
// the ESP32's secondary UART and late-bind the ISR function in setup().
|
|
Esp32Platform knxPlatform(&Serial2);
|
|
Bau07B0 knxBau(knxPlatform);
|
|
KnxFacade<Esp32Platform, Bau07B0> knx(knxBau);
|
|
|
|
ICACHE_RAM_ATTR void myButtonPressed()
|
|
{
|
|
// Debounce
|
|
static uint32_t lastpressed=0;
|
|
if (millis() - lastpressed > 200)
|
|
{
|
|
knx.toggleProgMode();
|
|
lastpressed = millis();
|
|
}
|
|
}
|
|
|
|
float currentValue = 0;
|
|
float maxValue = 0;
|
|
float minValue = RAND_MAX;
|
|
long lastsend = 0;
|
|
|
|
void measureTemp()
|
|
{
|
|
long now = millis();
|
|
if ((now - lastsend) < 2000)
|
|
return;
|
|
|
|
lastsend = now;
|
|
int r = rand();
|
|
currentValue = (r * 1.0) / (RAND_MAX * 1.0);
|
|
currentValue *= 100 * 100;
|
|
|
|
// write new value to groupobject
|
|
goCurrent.value(currentValue);
|
|
|
|
if (currentValue > maxValue)
|
|
{
|
|
maxValue = currentValue;
|
|
goMax.value(maxValue);
|
|
}
|
|
|
|
if (currentValue < minValue)
|
|
{
|
|
minValue = currentValue;
|
|
goMin.value(minValue);
|
|
}
|
|
}
|
|
|
|
// callback from reset-GO
|
|
void resetCallback(GroupObject& go)
|
|
{
|
|
if (go.value())
|
|
{
|
|
maxValue = 0;
|
|
minValue = 10000;
|
|
}
|
|
}
|
|
|
|
void setup()
|
|
{
|
|
knx.setButtonISRFunction(myButtonPressed);
|
|
|
|
Serial.begin(115200);
|
|
ArduinoPlatform::SerialDebug = &Serial;
|
|
|
|
Serial2.begin(19200); // KNX, pin 16,17 on EPS32
|
|
|
|
randomSeed(millis());
|
|
|
|
#ifdef ARDUINO_ARCH_ESP8266
|
|
WiFiManager wifiManager;
|
|
wifiManager.autoConnect("knx-demo");
|
|
#endif
|
|
|
|
// read adress table, association table, groupobject table and parameters from eeprom
|
|
knx.readMemory();
|
|
|
|
// print values of parameters if device is already configured
|
|
if (knx.configured())
|
|
{
|
|
// register callback for reset GO
|
|
goReset.callback(resetCallback);
|
|
goReset.dataPointType(DPT_Trigger);
|
|
goCurrent.dataPointType(DPT_Value_Temp);
|
|
goMin.dataPointType(DPT_Value_Temp);
|
|
goMax.dataPointType(DPT_Value_Temp);
|
|
|
|
Serial.print("Timeout: ");
|
|
Serial.println(knx.paramByte(0));
|
|
Serial.print("Zykl. senden: ");
|
|
Serial.println(knx.paramByte(1));
|
|
Serial.print("Min/Max senden: ");
|
|
Serial.println(knx.paramByte(2));
|
|
Serial.print("Aenderung senden: ");
|
|
Serial.println(knx.paramByte(3));
|
|
Serial.print("Abgleich: ");
|
|
Serial.println(knx.paramByte(4));
|
|
}
|
|
|
|
// pin or GPIO the programming led is connected to. Default is LED_BUILTIN
|
|
// knx.ledPin(LED_BUILTIN);
|
|
// is the led active on HIGH or low? Default is LOW
|
|
// knx.ledPinActiveOn(HIGH);
|
|
// pin or GPIO programming button is connected to. Default is 0
|
|
// knx.buttonPin(0);
|
|
|
|
// start the framework.
|
|
knx.start();
|
|
}
|
|
|
|
void loop()
|
|
{
|
|
// don't delay here to much. Otherwise you might lose packages or mess up the timing with ETS
|
|
knx.loop();
|
|
|
|
// only run the application code if the device was configured with ETS
|
|
if (!knx.configured())
|
|
return;
|
|
|
|
measureTemp();
|
|
}
|