Skip to content

iloveicedgreentea/madvr-envy-homeassistant

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

88 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

MadVR Envy Home Assistant

Attention

Note

🎉This custom component is now officially in core. https://www.home-assistant.io/integrations/madvr/ This repo is not the right place to get this integration anymore.🎉

This is the Home Assistant MadVR Envy Component implementing my MadVR Envy library

Features

  • Real time Attributes for Incoming Signal, Outgoing Signal, Aspect ratio
  • Wake on lan built in
  • HDR Flag to trigger brightness automation
  • Power off, standby
  • Navigation Keys
  • Profiles
  • Menu
  • etc

Why use this?

Automate your theater based on Envy attributes like HDR flag, aspect ratio etc. E.x If hdr_flag = true, set JVC picture mode to XYZ. The HDR flag for the envy is broken for NZ models so this is really useful.

You can also trigger masking systems based on the aspect ratio reported by Envy

Turn off Envy via IP control

Create remotes inside HA Dashboard to send commands like Menu, Right, etc. Basically remake the remote in the UI.

Installation

This is currently only a custom component. Unlikely to make it into HA core because their process is just too burdensome and I strongly disagree with their deployment model for integrations.

Install HACS, then install the component by adding this as a custom repo https://hacs.xyz/docs/faq/custom_repositories

You can also just copy all the files into your custom_components folder but then you won't get automatic updates.

Home Assistant Setup

Add this to configuration.yaml

I recommend a scan_interval of 3

remote:
  - platform: madvr
    name: envy
    host: 192.168.88.38
    mac: (mac addr)
    scan_interval: 3

When you call the remote.turn_off service, it will shut down the Envy and also close the TCP connection.

Profiles and 3D support

Set your profile to Source 2

For the following settings, save them to Source 2 Resolution: 1080p Menu: optimized for 1080p Screen Boundaries: None

Then use this plugin to send

ActivateProfile, SOURCE, 2

You can switch between 1 and 2 for 3d or 2d easily

You can also use CUSTOM and use your own profile groups.

Automate JVC Picture Modes for HDR

alias: JVC - Envy picture mode HDR
description: ""
trigger:
  - platform: state
    entity_id:
      - remote.envy
    attribute: hdr_flag
condition: []
action:
  - if:
      - condition: state
        entity_id: remote.envy
        attribute: hdr_flag
        state: true
    then:
      - service: remote.send_command
        data:
          command: picture_mode,user2
        target:
          entity_id: remote.nz7
  - if:
      - condition: state
        entity_id: remote.envy
        attribute: hdr_flag
        state: false
    then:
      - service: remote.send_command
        data:
          command: picture_mode,user1
        target:
          entity_id: remote.nz7
mode: single

Useful Stuff

I wrote this for my NZ7 but you can change the commands to Envy commands and it will work the same way.

I used this to re-create a remote in HA. Add the YAML to your dashboard to get a grid which resembles most of the remote. Other functions can be used via remote.send_command. See the library readme for details.

This is just an example. Add this sensor to your configuration.yml. Replace the nz7 with the name of your entity. Restart HA.

Add this to lovelace

square: false
columns: 3
type: grid
cards:
  - type: button
    name: Power
    show_icon: false
    entity: remote.nz7
    show_state: true
    show_name: true
    icon: mdi:power
  - type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: menu,up
      target:
        entity_id: remote.nz7
    show_name: false
    show_icon: true
    icon: mdi:arrow-up
    hold_action:
      action: none
  - type: button
    tap_action:
      action: none
    show_icon: false
    entity: sensor.jvc_low_latency
    show_name: true
    show_state: true
    name: Low Latency
    hold_action:
      action: none
  - type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: menu,left
      target:
        entity_id: remote.nz7
    show_name: false
    icon: mdi:arrow-left
  - show_name: false
    show_icon: true
    type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: menu, ok
      target:
        entity_id: remote.nz7
    name: OK
    icon: mdi:checkbox-blank-circle
    show_state: true
  - type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: menu, right
      target:
        entity_id: remote.nz7
    show_name: false
    icon: mdi:arrow-right
  - type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: menu,back
      target:
        entity_id: remote.nz7
    name: Back
    show_icon: false
  - type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: menu,down
      target:
        entity_id: remote.nz7
    show_name: false
    icon: mdi:arrow-down
  - type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: menu,menu
      target:
        entity_id: remote.nz7
    show_name: true
    show_icon: false
    name: Menu
    hold_action:
      action: none
  - show_name: true
    show_icon: true
    type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: installation_mode,mode5
      target:
        entity_id: remote.nz7
    name: '17:9'
    icon: mdi:television
    show_state: false
  - show_name: true
    show_icon: true
    type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: installation_mode,mode4
      target:
        entity_id: remote.nz7
    name: 2.4:1
    icon: mdi:television
    show_state: false
  - show_name: true
    show_icon: true
    type: button
    tap_action:
      action: call-service
      service: remote.send_command
      service_data:
        command: installation_mode,mode2
      target:
        entity_id: remote.nz7
    name: IMAX
    icon: mdi:television
    show_state: false

About

Home Assistant integration for MadVR Envy

Resources

Stars

Watchers

Forks

Sponsor this project

 

Packages

No packages published

Languages