FX: Usermod Temperature effect
This commit is contained in:
		| @@ -17,6 +17,8 @@ | ||||
| #define USERMOD_DALLASTEMPERATURE_MEASUREMENT_INTERVAL 60000 | ||||
| #endif | ||||
|  | ||||
| static uint16_t mode_temperature(); | ||||
|  | ||||
| class UsermodTemperature : public Usermod { | ||||
|  | ||||
|   private: | ||||
| @@ -60,6 +62,7 @@ class UsermodTemperature : public Usermod { | ||||
|     static const char _sensor[]; | ||||
|     static const char _temperature[]; | ||||
|     static const char _Temperature[]; | ||||
|     static const char _data_fx[]; | ||||
|      | ||||
|     //Dallas sensor quick (& dirty) reading. Credit to - Author: Peter Scargill, August 17th, 2013 | ||||
|     float readDallas(); | ||||
| @@ -70,8 +73,13 @@ class UsermodTemperature : public Usermod { | ||||
|     void publishHomeAssistantAutodiscovery(); | ||||
| #endif | ||||
|  | ||||
|     static UsermodTemperature* _instance; // to overcome nonstatic getTemperatureC() method and avoid usermods.lookup(USERMOD_ID_TEMPERATURE); | ||||
|  | ||||
|   public: | ||||
|  | ||||
|     UsermodTemperature() { _instance = this; } | ||||
|     static UsermodTemperature *getInstance() { return UsermodTemperature::_instance; } | ||||
|  | ||||
|     /* | ||||
|      * API calls te enable data exchange between WLED modules | ||||
|      */ | ||||
| @@ -234,6 +242,7 @@ void UsermodTemperature::setup() { | ||||
|       } | ||||
|       temperaturePin = -1;  // allocation failed | ||||
|     } | ||||
|     if (sensorFound && !initDone) strip.addEffect(255, &mode_temperature, _data_fx); | ||||
|   } | ||||
|   lastMeasurement = millis() - readingInterval + 10000; | ||||
|   initDone = true; | ||||
| @@ -440,6 +449,8 @@ const char *UsermodTemperature::getTemperatureUnit() { | ||||
|   return degC ? "°C" : "°F"; | ||||
| } | ||||
|  | ||||
| UsermodTemperature* UsermodTemperature::_instance = nullptr; | ||||
|  | ||||
| // strings to reduce flash memory usage (used more than twice) | ||||
| const char UsermodTemperature::_name[]         PROGMEM = "Temperature"; | ||||
| const char UsermodTemperature::_enabled[]      PROGMEM = "enabled"; | ||||
| @@ -449,4 +460,14 @@ const char UsermodTemperature::_parasitePin[]  PROGMEM = "parasite-pwr-pin"; | ||||
| const char UsermodTemperature::_domoticzIDX[]  PROGMEM = "domoticz-idx"; | ||||
| const char UsermodTemperature::_sensor[]       PROGMEM = "sensor"; | ||||
| const char UsermodTemperature::_temperature[]  PROGMEM = "temperature"; | ||||
| const char UsermodTemperature::_Temperature[]  PROGMEM = "/temperature"; | ||||
| const char UsermodTemperature::_Temperature[]  PROGMEM = "/temperature"; | ||||
| const char UsermodTemperature::_data_fx[]      PROGMEM = "Temperature@Min,Max;;!;01;pal=54"; | ||||
|  | ||||
| static uint16_t mode_temperature() { | ||||
|   float low  = mapf((float)SEGMENT.speed, 0.f, 255.f, -150.f, 149.9f);    // default: 0°C, range: -15°C to 15°C | ||||
|   float high = mapf((float)SEGMENT.intensity, 0.f, 255.f, 150.f, 450.f);  // default: 30°C, range 15°C to 45°C | ||||
|   float temp = constrain(UsermodTemperature::getInstance()->getTemperatureC()*10.f, low, high);   // get a little better resolution | ||||
|   unsigned i = map(temp, (unsigned)low, (unsigned)high, 0, 255); | ||||
|   SEGMENT.fill(SEGMENT.color_from_palette(i, false, false, 255)); | ||||
|   return FRAMETIME; | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Blaz Kristan
					Blaz Kristan