Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

A home-assistant-friendly mqtt-enabled service to control your display with a dedicated device

License

NotificationsYou must be signed in to change notification settings

moimart/ddc-mqtt

Repository files navigation

"Buy Me A Coffee"

  • Do you have a display with multiple inputs?
  • Would you like to be able to switch inputs without the need of meddling with clunky OSD menus and akwardly-positioned control 'nipples'?
  • Does this happen to you even with fancy, expensive displays like the Neo G9 line from Samsung?
  • Can you imagine KVM scenarios based on home assistant automations?

Then this software is for you!!!

You only need a Linux machine connected to the display, a bit of knowledge on your display's support of DDC capabilities and this willcreate a device for your Home Assistance (or your MQTT setup) so you can control the display

Display's DDC capabilities

First of all, you'd need some info about your display and its DDC capabilities wrt display inputs. You'd need theddcutil tool to figurethings out. For example: this is what my G95NC Samsung Neo G9 Reports:

$ ddcutil capabilitiesModel: FALCONMCCS version: 2.0Commands:   Op Code: 01 (VCP Request)   Op Code: 02 (VCP Response)   Op Code: 03 (VCP Set)   Op Code: 07 (Timing Request)   Op Code: 0C (Save Settings)   Op Code: E3 (Capabilities Reply)   Op Code: F3 (Capabilities Request)VCP Features:   Feature: 02 (New control value)   Feature: 04 (Restore factory defaults)   Feature: 05 (Restore factory brightness/contrast defaults)   Feature: 08 (Restore color defaults)   Feature: 10 (Brightness)   Feature: 12 (Contrast)   Feature: 14 (Select color preset)      Values:         05: 6500 K         08: 9300 K         0b: User 1         0c: User 2   Feature: 16 (Video gain: Red)   Feature: 18 (Video gain: Green)   Feature: 1A (Video gain: Blue)   Feature: 52 (Active control)   Feature: 60 (Input Source)      Values:         01: VGA-1         03: DVI-1         04: DVI-2         11: HDMI-1         12: HDMI-2         0f: DisplayPort-1         10: DisplayPort-2   Feature: 62 (Audio speaker volume)   Feature: 8D (Audio Mute)   Feature: FF (Manufacturer specific feature)

We'll focus on theFeature: 60 (Input Source) ... I have good news and bad news:

  1. Good news: The display supports changing inputs with DDC!
  2. Bad news:The inputs and the values are, for the most part, bullsh*t!!

Because of this, we will need to figure out the actual input values for each actual input of the monitor.

You can useddcutil again to figure them out like so:

# change the last number to figure the actual values that change the input. # Have in mind these are hexadecimal values you'll need to convert to integers$ sudo ddcutil setvcp 0x60 0x01

Configuration

Once you have the values for the inputs you want to control, you can fill out the config.yml inside the folder ddc-mqtt that you'd need for the software to run. For my display this would be:

mqtt:  username: #your mqtt server's username  password: #your mqtt server's password  host: 1.2.3.4 #your mqtt server's host  port: 1883display:  - id: 1 #display to control. if only a single monitor, this must be 1    inputs:      HDMI1: 5 # key: value — you can change the name of the input.       HDMI2: 6 # The codes here are input as integers, not hexadecimal      HDMI3: 7      DP: 15interval: 20

Setup

You might want to use the docker container that comes with the code. If you use a Raspberry Pi you just do:

$ docker-compose up -d

And if your config is well formed, that should be it!

If you don't use a Raspberry Pi, you might need to pay attention to thedocker-compose.yml in the root folder as we areforwarding the i2c devices for the ddcutil library to access.

    devices:      - "/dev/i2c-20:/dev/i2c-20"      - "/dev/i2c-21:/dev/i2c-21" #these might be different in your machine

Usage

If your MQTT server is shared or is part of aHome Assistant setup, the usage is simple. You'll get a device with switches to change inputs and that's all!

Display KVM'

If you want to use it MQTT RAW!!! you'd have access to the entities in the following paths:

Subscribe to kikkei/display-kvm/{number_of_display}/{input_name_in_the_config}/state -> with values 'true' or 'false' to check the statePublish 'ON' to kikkei/display-kvm/{number_of_display}/{input_name_in_the_config}/command for activation -> no need to send 'OFF'; switching is taken care ofExample: kikkei/display-kvm/1/HDMI1/state

Observations

This software is polling at an interval to re-check of the state of the active input— just in case you switch it manually...

This interval can be configured in the config.yml with the key interval. It is optional and by default is 20 seconds...

I coded this to support multiple monitors but I have not tested it at all... contributions are very welcome! :)

Hope it works for you as well as it works for me!

About

A home-assistant-friendly mqtt-enabled service to control your display with a dedicated device

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

[8]ページ先頭

©2009-2025 Movatter.jp