Gå til innhold
  • Bli medlem
Støtt hjemmeautomasjon! 🥇🥈🥉

Anbefalte innlegg

Skrevet (endret)

Jeg har tullet en stund med dette, kanskje det er flere som prøver med det samme? Målet mitt var å få fargekodet strømpriser dynamisk basert på dagens prisnivåer. Jeg mener nå jeg har funnet et oppsett som er ganske bra. Grafen i bakgrunnen er prisene for i dag (og i morgen når tilgjengelig), og de fargekodes ut ifra dagens min, max og mean fra nordpool sensorens attributter. Fargen i tittelen (60 øre/kWh) endres også basert på prisen 'nå', og det samme gjør linjen på grafen. Jeg er litt usikker på hva jeg liker best, men du kan skru av og på linjen på grafen ved å endre stroke_width: under series: mellom 0 og 1 (eller større / tykkere om du vil). 

 

image.png.7788ba921d9fb83523767d8b136cfe2c.png

 

 

Dark mode på mobil. 

image.thumb.png.29b4d977b6e871c92b97a7f81c074f25.png

 

Her er kortet i lovelace. Bare endre sensor_price og sensor_usage, samt oppdater enhet for low_price, high_price og mean_price. 

 

type: custom:config-template-card
variables:
  sensor_price: '"sensor.nordpool"'
  sensor_usage: '"sensor.accumulated_consumption_current_hour_gatenavn_1"'
  low_price: states['sensor.nordpool'].attributes.min
  high_price: states['sensor.nordpool'].attributes.max
  mean_price: states['sensor.nordpool'].attributes.mean
  current_price: states['sensor.nordpool'].state
  state_color: |
    (low, high, current) => {
      const range = high - low;
      const third_low = low + range / 3;
      const third_high = high - range / 3;

      if (current <= third_low) {
        return '#42a047';  // Grønn
      } else if (current <= third_high) {
        return '#ffa600';  // Oransje
      } else {
        return '#db4437';  // Rød
      }
    }
entities:
  - ${sensor_price}
card:
  type: custom:apexcharts-card
  experimental:
    color_threshold: true
  header:
    show: true
    title: Strømpris og Forbruk
    show_states: true
    standard_format: true
    colorize_states: true
  now:
    show: true
    label: Nå
  graph_span: 2d
  span:
    start: day
  apex_config:
    dataLabels:
      enabled: true
    legend:
      show: true
    chart:
      height: 210px
    yaxis:
      - id: price
        show: true
        decimalsInFloat: 0
        floating: false
        forceNiceScale: true
        extend_to: end
      - id: usage
        show: true
        opposite: true
        decimalsInFloat: 0
        floating: false
        forceNiceScale: true
        extend_to: end
  series:
    - entity: ${sensor_price}
      yaxis_id: price
      extend_to: now
      name: Pris
      unit: ' øre/kWh'
      stroke_width: 1
      type: area
      curve: stepline
      float_precision: 0
      color: ${state_color(low_price, high_price, current_price)}
      color_threshold:
        - value: ${low_price}
          color: '#42a047'
        - value: ${mean_price}
          color: '#ffa600'
        - value: ${high_price}
          color: '#db4437'
      show:
        legend_value: false
        in_header: before_now
      data_generator: >
        return (entity.attributes.raw_today.map((start, index) => { return [new
        Date(start["start"]).getTime(),
        entity.attributes.raw_today[index]["value"]];
        })).concat(entity.attributes.raw_tomorrow.map((start, index) => { return
        [new Date(start["start"]).getTime(),
        entity.attributes.raw_tomorrow[index]["value"]]; }));
    - entity: ${sensor_usage}
      yaxis_id: usage
      type: column
      name: Forbruk
      stroke_width: 2
      invert: false
      group_by:
        func: max
      show:
        legend_value: false

 

 

Før morgendagens priser:

Screenshot2024-08-17at11_46_29.png.8a65d86a9e2ab983ef947ffb55d871b9.png

Endret av sbarmen
  • Like 1
Skrevet

Kan man få linjen til å endre farge uten fyll? Jeg har tre prisgrafer og en graf med fyll i kortet mitt så hos meg blir det litt vanskeligere.

Skrevet

Nei, linjen har bare en farge. Det er samme farge som prisen i mitt eksempel. Men du kan kun ha 1 farge på linja. Alternativt til fyll er å bruke column. 

  • 2 måneder senere...
Skrevet

Takk for tips, sjekker ut!

 

Stemte det, ja.

image.thumb.png.42c663b2dc79a7870e666837d1e820fb.png

 

Tester på endre. Ser ut til at jeg må slette og lette den til igjen.

 

Fint kort forøvrig, takk for deling.

  • 2 måneder senere...
Skrevet

Hei @sbarmen - veldig fin chart du har satt sammen her 😊

Prøvde å legge inn nå, men får følgende feilmelding:

/// apexcharts-card version 2.1.2 /// value.series[0] is not a ChartCardSeriesExternalConfig; value.series[0].color_threshold[0] is not a ChartCardColorThreshold; value.series[0].color_threshold[0].value is missing
type: custom:apexcharts-card
experimental:
  color_threshold: true
header:
  show: true
  title: Strømpris og Forbruk
  show_states: true
  standard_format: true
  colorize_states: true
now:
  show: true
  label: Nå
graph_span: 2d
span:
  start: day
apex_config:
  dataLabels:
    enabled: true
  legend:
    show: true
  chart:
    height: 210px
  yaxis:
    - id: price
      show: true
      decimalsInFloat: 0
      floating: false
      forceNiceScale: true
      extend_to: end
    - id: usage
      show: true
      opposite: true
      decimalsInFloat: 0
      floating: false
      forceNiceScale: true
      extend_to: end
series:
  - entity: sensor.nord_pool_no3_current_price
    yaxis_id: price
    extend_to: now
    name: Pris
    unit: ' øre/kWh'
    stroke_width: 1
    type: area
    curve: stepline
    float_precision: 0
    color: '#db4437'
    color_threshold:
      - color: '#42a047'
      - color: '#ffa600'
      - color: '#db4437'
    show:
      legend_value: false
      in_header: before_now
    data_generator: >
      return (entity.attributes.raw_today.map((start, index) => { return [new
      Date(start["start"]).getTime(),
      entity.attributes.raw_today[index]["value"]];
      })).concat(entity.attributes.raw_tomorrow.map((start, index) => { return
      [new Date(start["start"]).getTime(),
      entity.attributes.raw_tomorrow[index]["value"]]; }));
  - entity: sensor.tibber_pulse_hjem_accumulated_consumption_current_hour
    yaxis_id: usage
    type: column
    name: Forbruk
    stroke_width: 2
    invert: false
    group_by:
      func: max
    show:
      legend_value: false

 

Klarer du å se hvorfor?

Mener jeg har lagt inn sensorene riktig. Men ser Nor Pool ikke har mean price-sensor, så la inn annen sensor i stedet.

 

Her er koden jeg la inn:

type: custom:config-template-card
variables:
  sensor_price: "\"sensor.nord_pool_no3_current_price\""
  sensor_usage: "\"sensor.tibber_pulse_hjem_accumulated_consumption_current_hour\""
  low_price: states['sensor.nord_pool_no3_lowest_price'].attributes.min
  high_price: states['sensor.nord_pool_no3_highest_price'].attributes.max
  mean_price: states['sensor.nord_pool_no3_next_price'].attributes.mean
  current_price: states['sensor.nord_pool_no3_current_price'].state
  state_color: |
    (low, high, current) => {
      const range = high - low;
      const third_low = low + range / 3;
      const third_high = high - range / 3;

      if (current <= third_low) {
        return '#42a047';  // Grønn
      } else if (current <= third_high) {
        return '#ffa600';  // Oransje
      } else {
        return '#db4437';  // Rød
      }
    }
entities:
  - ${sensor_price}
card:
  type: custom:apexcharts-card
  experimental:
    color_threshold: true
  header:
    show: true
    title: Strømpris og Forbruk
    show_states: true
    standard_format: true
    colorize_states: true
  now:
    show: true
    label: Nå
  graph_span: 2d
  span:
    start: day
  apex_config:
    dataLabels:
      enabled: true
    legend:
      show: true
    chart:
      height: 210px
    yaxis:
      - id: price
        show: true
        decimalsInFloat: 0
        floating: false
        forceNiceScale: true
        extend_to: end
      - id: usage
        show: true
        opposite: true
        decimalsInFloat: 0
        floating: false
        forceNiceScale: true
        extend_to: end
  series:
    - entity: ${sensor_price}
      yaxis_id: price
      extend_to: now
      name: Pris
      unit: " øre/kWh"
      stroke_width: 1
      type: area
      curve: stepline
      float_precision: 0
      color: ${state_color(low_price, high_price, current_price)}
      color_threshold:
        - value: ${low_price}
          color: "#42a047"
        - value: ${mean_price}
          color: "#ffa600"
        - value: ${high_price}
          color: "#db4437"
      show:
        legend_value: false
        in_header: before_now
      data_generator: >
        return (entity.attributes.raw_today.map((start, index) => { return [new
        Date(start["start"]).getTime(),
        entity.attributes.raw_today[index]["value"]];
        })).concat(entity.attributes.raw_tomorrow.map((start, index) => { return
        [new Date(start["start"]).getTime(),
        entity.attributes.raw_tomorrow[index]["value"]]; }));
    - entity: ${sensor_usage}
      yaxis_id: usage
      type: column
      name: Forbruk
      stroke_width: 2
      invert: false
      group_by:
        func: max
      show:
        legend_value: false

 

Gjest
Skriv svar til emnet...

×   Du har limt inn tekst med formatering.   Lim inn uten formatering i stedet

  Du kan kun bruke opp til 75 smilefjes.

×   Lenken din har blitt bygget inn på siden automatisk.   Vis som en ordinær lenke i stedet

×   Tidligere tekst har blitt gjenopprettet.   Tøm tekstverktøy

×   Du kan ikke lime inn bilder direkte. Last opp eller legg inn bilder fra URL.

×
×
  • Opprett ny...

Viktig informasjon

Vi har plassert informasjonskapsler/cookies på din enhet for å gjøre denne siden bedre. Du kan justere dine innstillinger for informasjonskapsler, ellers vil vi anta at dette er ok for deg.