Added, CO2, removed obsolete sensors, minor code cleanups, minor design modifications.
This commit is contained in:
		@@ -78,6 +78,10 @@ sensor:
 | 
			
		||||
  - platform: homeassistant
 | 
			
		||||
    entity_id: sensor.wohnzimmer_luftfeuchtigkeit
 | 
			
		||||
    id: humid_livingroom
 | 
			
		||||
 | 
			
		||||
  - platform: homeassistant
 | 
			
		||||
    entity_id: sensor.wohnzimmer_co2
 | 
			
		||||
    id: co2_livingroom
 | 
			
		||||
  
 | 
			
		||||
  - platform: homeassistant
 | 
			
		||||
    entity_id: sensor.temperatur_aussen
 | 
			
		||||
@@ -91,16 +95,6 @@ sensor:
 | 
			
		||||
    entity_id: sensor.schlafzimmer_luftdruck
 | 
			
		||||
    id: airpressure
 | 
			
		||||
 | 
			
		||||
  - platform: homeassistant
 | 
			
		||||
    entity_id: zone.home
 | 
			
		||||
    attribute: latitude
 | 
			
		||||
    id: home_lat
 | 
			
		||||
 | 
			
		||||
  - platform: homeassistant
 | 
			
		||||
    entity_id: zone.home
 | 
			
		||||
    attribute: longitude
 | 
			
		||||
    id: home_long
 | 
			
		||||
 | 
			
		||||
text_sensor:
 | 
			
		||||
  - platform: homeassistant
 | 
			
		||||
    entity_id: sun.sun
 | 
			
		||||
@@ -119,25 +113,11 @@ text_sensor:
 | 
			
		||||
    attribute: next_setting
 | 
			
		||||
    internal: True
 | 
			
		||||
 | 
			
		||||
#  - platform: sun
 | 
			
		||||
#    name: "Nächster Sonnenaufgang"
 | 
			
		||||
#    id: sun_rise
 | 
			
		||||
#    type: sunrise
 | 
			
		||||
#    format: "%H:%M"
 | 
			
		||||
#    internal: True
 | 
			
		||||
 | 
			
		||||
#  - platform: sun
 | 
			
		||||
#    name: "Nächster Sonnenuntergang"
 | 
			
		||||
#    id: sun_set
 | 
			
		||||
#    type: sunset
 | 
			
		||||
#    format: "%H:%M"
 | 
			
		||||
#    internal: True
 | 
			
		||||
 | 
			
		||||
  - platform: homeassistant
 | 
			
		||||
    entity_id: sensor.moon
 | 
			
		||||
    id: moonphase
 | 
			
		||||
 | 
			
		||||
# Webserver configuration entry
 | 
			
		||||
# Webserver configuration
 | 
			
		||||
web_server:
 | 
			
		||||
  port: 80
 | 
			
		||||
#  css_include: "esphome-docs/_static/webserver-v1.min.css"
 | 
			
		||||
@@ -148,11 +128,6 @@ web_server:
 | 
			
		||||
    username: admin
 | 
			
		||||
    password: !secret web_server_password
 | 
			
		||||
 | 
			
		||||
sun:
 | 
			
		||||
  latitude: id(home_lat)
 | 
			
		||||
  longitude: id(home_long)
 | 
			
		||||
  id: sun_sun
 | 
			
		||||
 | 
			
		||||
time:
 | 
			
		||||
  - platform: homeassistant
 | 
			
		||||
    id: homeassistant_time
 | 
			
		||||
@@ -172,7 +147,7 @@ font:
 | 
			
		||||
       'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S',
 | 
			
		||||
       'T', 'U', 'V', 'W', 'X', 'Y', 'Z', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
 | 
			
		||||
       'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't',
 | 
			
		||||
       'u', 'v', 'w', 'x', 'y', 'z','å', 'ä', 'ö', '/','º','µ','³','ß']
 | 
			
		||||
       'u', 'v', 'w', 'x', 'y', 'z', 'å', 'ä', 'ö', '/', 'º', 'µ', '³', 'ß']
 | 
			
		||||
 | 
			
		||||
  - file: 'fonts/Roboto-Regular.ttf'
 | 
			
		||||
    id: big_sensor_unit
 | 
			
		||||
@@ -183,7 +158,7 @@ font:
 | 
			
		||||
       'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S',
 | 
			
		||||
       'T', 'U', 'V', 'W', 'X', 'Y', 'Z', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
 | 
			
		||||
       'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't',
 | 
			
		||||
       'u', 'v', 'w', 'x', 'y', 'z', 'å', 'ä', 'ö', '/','º','µ','³','ß']
 | 
			
		||||
       'u', 'v', 'w', 'x', 'y', 'z', 'å', 'ä', 'ö', '/', 'º', 'µ', '³', 'ß']
 | 
			
		||||
       
 | 
			
		||||
  - file: 'fonts/Roboto-Medium.ttf'
 | 
			
		||||
    id: sub_sensor_font
 | 
			
		||||
@@ -194,17 +169,17 @@ font:
 | 
			
		||||
       'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S',
 | 
			
		||||
       'T', 'U', 'V', 'W', 'X', 'Y', 'Z', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
 | 
			
		||||
       'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't',
 | 
			
		||||
       'u', 'v', 'w', 'x', 'y', 'z', 'å', 'ä', 'ö', '/','º','µ','³','ß']
 | 
			
		||||
       'u', 'v', 'w', 'x', 'y', 'z', 'å', 'ä', 'ö', '/', 'º', 'µ', '³', 'ß']
 | 
			
		||||
  
 | 
			
		||||
  - file: 'fonts/Roboto-Bold.ttf'
 | 
			
		||||
    id: big_sensor_font
 | 
			
		||||
    size: 80
 | 
			
		||||
    size: 50
 | 
			
		||||
  
 | 
			
		||||
  - file: 'fonts/materialdesignicons-webfont.ttf'
 | 
			
		||||
    id:  mdi_small
 | 
			
		||||
    size: 31
 | 
			
		||||
    glyphs: [
 | 
			
		||||
      '', # mdi-themometer
 | 
			
		||||
      '', # mdi-thermometer
 | 
			
		||||
      '', # mdi-water-percent
 | 
			
		||||
      '', # mdi-blur (pm2.5)
 | 
			
		||||
      '', # mdi-co2
 | 
			
		||||
@@ -219,14 +194,14 @@ font:
 | 
			
		||||
      '', # mdi-moon-waning-crescent
 | 
			
		||||
      '', # mdi-moon-waning-gibbous
 | 
			
		||||
      '', # mdi-moon-waxing-crescent
 | 
			
		||||
      '', # mdi-moon-waxing-gibbous
 | 
			
		||||
      '' # mdi-moon-waxing-gibbous
 | 
			
		||||
      ]
 | 
			
		||||
 | 
			
		||||
  - file: 'fonts/materialdesignicons-webfont.ttf'
 | 
			
		||||
    id:  mdi_wifi
 | 
			
		||||
    size: 20
 | 
			
		||||
    glyphs: [
 | 
			
		||||
      # Wifi
 | 
			
		||||
      # WiFi
 | 
			
		||||
      '', # mdi-wifi-strength-alert-outline
 | 
			
		||||
      '', # mdi-wifi-strength-1
 | 
			
		||||
      '', # mdi-wifi-strength-2
 | 
			
		||||
@@ -265,15 +240,17 @@ display:
 | 
			
		||||
      float livingroom_temp = id(temp_livingroom).state;
 | 
			
		||||
      int livingroom_humid = int(id(humid_livingroom).state);
 | 
			
		||||
      int livingroom_pm25 = int(id(pm25_livingroom).state);
 | 
			
		||||
      float livingroom_co2 = id(co2_livingroom).state;
 | 
			
		||||
      char sunrise[5] = "";
 | 
			
		||||
      char sunset[5] = "";
 | 
			
		||||
 | 
			
		||||
      /*
 | 
			
		||||
      This is Commander1024 doing awful string / time fuckerey full of
 | 
			
		||||
      desperation to format sunrise / sunset times.
 | 
			
		||||
      Don't be like Commander1024
 | 
			
		||||
 | 
			
		||||
      // This is Commander1024 doing awful string / time fuckerey full of
 | 
			
		||||
      // desperation to format sunrise / sunset times.
 | 
			
		||||
      // Don't be like Commander1024
 | 
			
		||||
 | 
			
		||||
      // Format: 2021-10-08T05:40:47.467076+00:00 -> 7:40 (dst)
 | 
			
		||||
      Format: 2021-10-08T05:40:47.467076+00:00 -> 7:40 (dst)
 | 
			
		||||
      */
 | 
			
		||||
      int dst = id(homeassistant_time).now().is_dst; // returns 1 for dst, otherwise 0
 | 
			
		||||
      struct tm tm;
 | 
			
		||||
      memset (&tm, 0, sizeof (tm));
 | 
			
		||||
@@ -291,27 +268,23 @@ display:
 | 
			
		||||
 | 
			
		||||
      /* OUTSIDE */
 | 
			
		||||
      it.print(10, 10, id(big_sensor_unit), "Umwelt");
 | 
			
		||||
      // Draw the outline of a rectangle with the top left at [78,21], a width of 305 and a height of 3
 | 
			
		||||
      /*
 | 
			
		||||
      Draw the outline of a rectangle with the top left at [78,21],
 | 
			
		||||
      a width of 305 and a height of 3
 | 
			
		||||
      */
 | 
			
		||||
      it.filled_rectangle(86, 21, 297, 3);
 | 
			
		||||
      if(id(sun_state).has_state()) {
 | 
			
		||||
        ESP_LOGI("Sun", "State of the sun: %s", id(sun_state).state.c_str());
 | 
			
		||||
        ESP_LOGD("Sun", "Sunrise: %s", sunrise);
 | 
			
		||||
        ESP_LOGD("Sun", "Sunset: %s", sunset);
 | 
			
		||||
        ESP_LOGI("Sun", "State of the sun: %s, sunrise: %s, sunset: %s",
 | 
			
		||||
                 id(sun_state).state.c_str(), sunrise, sunset);
 | 
			
		||||
 | 
			
		||||
        //if(id(sun_state).state == "above_horizon") {
 | 
			
		||||
          it.print(10, 75, id(mdi_small), TextAlign::BASELINE_LEFT, ""); //sun-up
 | 
			
		||||
          it.printf(50, 75, id(big_sensor_unit), TextAlign::BASELINE_LEFT, "%s", sunrise);
 | 
			
		||||
          it.print(135, 75, id(mdi_small), TextAlign::BASELINE_LEFT, ""); //sun-down
 | 
			
		||||
          it.printf(175, 75, id(big_sensor_unit), TextAlign::BASELINE_LEFT, "%s", sunset);
 | 
			
		||||
        //}
 | 
			
		||||
        //else {
 | 
			
		||||
          //it.print(10, 75, id(mdi_small), TextAlign::BASELINE_LEFT, ""); //sun-down
 | 
			
		||||
          //it.strftime(50, 75, id(footer_font), TextAlign::BASELINE_LEFT, "Nächster Sonnenaufgang %d.%m.%Y %H:%M", id(sun_rise));
 | 
			
		||||
        //}
 | 
			
		||||
        it.print(10, 75, id(mdi_small), TextAlign::BASELINE_LEFT, ""); // sun-up
 | 
			
		||||
        it.printf(50, 75, id(big_sensor_unit), TextAlign::BASELINE_LEFT, "%s", sunrise);
 | 
			
		||||
        it.print(135, 75, id(mdi_small), TextAlign::BASELINE_LEFT, ""); // sun-down
 | 
			
		||||
        it.printf(175, 75, id(big_sensor_unit), TextAlign::BASELINE_LEFT, "%s", sunset);
 | 
			
		||||
      }
 | 
			
		||||
      it.print(250, 115, id(mdi_small), TextAlign::BASELINE_CENTER, ""); //air-pressure
 | 
			
		||||
      it.print(375, 75,  id(mdi_small), TextAlign::BASELINE_CENTER, ""); //thermometer
 | 
			
		||||
      it.print(375, 115, id(mdi_small), TextAlign::BASELINE_CENTER, ""); //water-percent
 | 
			
		||||
      it.print(250, 115, id(mdi_small), TextAlign::BASELINE_CENTER, ""); // air pressure icon
 | 
			
		||||
      it.print(375, 75,  id(mdi_small), TextAlign::BASELINE_CENTER, ""); // thermometer icon
 | 
			
		||||
      it.print(375, 115, id(mdi_small), TextAlign::BASELINE_CENTER, ""); // water percent icon
 | 
			
		||||
 | 
			
		||||
      if(outdoor_temp > -100 && outdoor_temp < 100) {
 | 
			
		||||
        it.printf(357, 75, id(sub_sensor_font), TextAlign::BASELINE_RIGHT, "%2.1fºC", outdoor_temp);
 | 
			
		||||
@@ -327,10 +300,10 @@ display:
 | 
			
		||||
        it.print(357, 115, id(sub_sensor_font), TextAlign::BASELINE_RIGHT, " -  %");
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      if(air_pressure < 1200 && air_pressure >=800) { //Has valid value
 | 
			
		||||
      if(air_pressure < 1200 && air_pressure >=800) { // Has valid value
 | 
			
		||||
        it.printf(228, 115, id(sub_sensor_font), TextAlign::BASELINE_RIGHT, "%4.1fhPa", air_pressure);
 | 
			
		||||
      }
 | 
			
		||||
      else { //Invalid or error value
 | 
			
		||||
      else { // Invalid or error value
 | 
			
		||||
        it.print(228, 115, id(sub_sensor_font), TextAlign::BASELINE_RIGHT, "- hPa");
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
@@ -377,14 +350,15 @@ display:
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      /* INSIDE */
 | 
			
		||||
      /* Livingroom */
 | 
			
		||||
 | 
			
		||||
      int offsetY = 137;
 | 
			
		||||
      it.print(10, 10 + offsetY, id(big_sensor_unit), "INSIDE");
 | 
			
		||||
      it.filled_rectangle(78, 21 + offsetY, 305, 3);
 | 
			
		||||
      it.print(10, 10 + offsetY, id(big_sensor_unit), "Wohnzimmer");
 | 
			
		||||
      it.filled_rectangle(136, 21 + offsetY, 247, 3);
 | 
			
		||||
      it.print(10, 114 + offsetY, id(big_sensor_unit), TextAlign::BASELINE_LEFT, "PM2.5");
 | 
			
		||||
      it.print(375, 75 + offsetY,  id(mdi_small), TextAlign::BASELINE_CENTER, ""); //thermometer
 | 
			
		||||
      it.print(375, 115 + offsetY, id(mdi_small), TextAlign::BASELINE_CENTER, ""); //water-percent
 | 
			
		||||
      it.print(375, 75 + offsetY,  id(mdi_small), TextAlign::BASELINE_CENTER, ""); // thermometer
 | 
			
		||||
      it.print(375, 115 + offsetY, id(mdi_small), TextAlign::BASELINE_CENTER, ""); // water percent
 | 
			
		||||
      it.print(10, 75 + offsetY, id(mdi_small), TextAlign::BASELINE_LEFT, ""); // co2
 | 
			
		||||
 | 
			
		||||
      if(livingroom_temp > -100 && livingroom_temp < 100){
 | 
			
		||||
        it.printf(357, 75 + offsetY, id(sub_sensor_font), TextAlign::BASELINE_RIGHT , "%2.1fºC", livingroom_temp);
 | 
			
		||||
@@ -398,6 +372,11 @@ display:
 | 
			
		||||
        it.print(357, 115 + offsetY, id(sub_sensor_font), TextAlign::BASELINE_RIGHT , " -  %");
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      if(livingroom_co2 >=380 && livingroom_co2 <= 20000){
 | 
			
		||||
        it.printf(50, 75 + offsetY, id(sub_sensor_font), TextAlign::BASELINE_LEFT , "%4.1fppm", livingroom_co2);
 | 
			
		||||
      }else{
 | 
			
		||||
        it.print(50, 75 + offsetY, id(sub_sensor_font), TextAlign::BASELINE_LEFT , " -  ppm");
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      if(livingroom_pm25 < 255 && livingroom_pm25 >=0){
 | 
			
		||||
        if (livingroom_pm25 > 99){
 | 
			
		||||
@@ -409,18 +388,18 @@ display:
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if(livingroom_pm25 >= pm25_danger_thres){
 | 
			
		||||
          it.print(37, 87 + offsetY, id(mdi_med), TextAlign::BASELINE_CENTER, ""); //warning
 | 
			
		||||
          it.print(37, 87 + offsetY, id(mdi_med), TextAlign::BASELINE_CENTER, ""); // warning
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
      }
 | 
			
		||||
      else{
 | 
			
		||||
      else {
 | 
			
		||||
        it.print(175, 114 + offsetY, id(big_sensor_font), TextAlign::BASELINE_RIGHT , "- ");
 | 
			
		||||
        it.print(180, 114 + offsetY, id(big_sensor_unit),TextAlign::BASELINE_LEFT, "µg/m³");
 | 
			
		||||
      } 
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
      /* FOOTER */
 | 
			
		||||
      it.strftime(610, 374 , id(footer_font), TextAlign::BASELINE_RIGHT , "Letzte Aktualisierung %d.%m.%Y %H:%M", id(homeassistant_time).now());
 | 
			
		||||
      it.strftime(610, 374 , id(footer_font), TextAlign::BASELINE_RIGHT , "Aktualisiert um %d.%m.%Y %H:%M", id(homeassistant_time).now());
 | 
			
		||||
      
 | 
			
		||||
      /* WiFi Signal Strenght */
 | 
			
		||||
      if(id(wifisignal).has_state()) {
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user