# Oppo Blu-ray player Binding

This binding can be used to control the Oppo UDP-203/205 or BDP-83/93/95/103/105 Blu-ray player. Almost all features of the various models of this player line are supported by the binding. Please review the notes below for some important usage caveats.

The binding supports three different kinds of connections:

  • direct IP connection (with caveats),
  • serial connection,
  • serial over IP connection

For users without a serial port on the server side, you can use a USB to serial adapter.

You don't need to have your player device directly connected to your openHAB server. You can connect it for example to a Raspberry Pi and use ser2net Linux tool (opens new window) to make the serial connection available on the LAN (serial over IP).

# Supported Things

There is exactly one supported thing type, which represents the player. It has the player id.

# Discovery

Manually initiated Auto-discovery is supported if the player is accessible on the same IP subnet of the openHAB server. In the Inbox, select Search For Things and then choose the Oppo Blu-ray Player Binding to initiate discovery.

# Binding Configuration

There are no overall binding configuration settings that need to be set. All settings are through thing configuration parameters.

# Thing Configuration

The thing has the following configuration parameters:

Parameter Label Parameter ID Description Accepted values
Player Model model Specifies what model of player is to be controlled by the binding (required). 83, 103, 105, 203, or 205
Address host Host name or IP address of the Oppo player or serial over IP device. host name or ip
Port port Communication port for using serial over IP. Leave blank if using direct IP connection to the player. ip port number
Serial Port serialPort Serial port to use for directly connecting to the Oppo player a comm port name
Verbose Mode verboseMode (Optional) If true, the player will send time updates every second. If set false, the binding polls the player every 10 seconds. Boolean; default false

Some notes:

  • If using direct IP connection on the BDP series (83/93/95/103/105), verbose mode is not supported.

  • For some reason on these models, the unsolicited status update messages are not generated over the IP socket.

  • If fast updates are required on these models, a direct serial or serial over IP connection to the player is required.

  • The UDP-20x series should be fully functional over direct IP connection but this was not able to be tested by the developer.

  • As previously noted, when using verbose mode, the player will send time code messages once per second while playback is ongoing.

  • Be aware that this could cause performance impacts to your openHAB system.

  • In non-verbose (the default), the binding will poll the player every 10 seconds to update play time, track and chapter information instead.

  • In order for the direct IP connection to work while the player is turned off, the Standby Mode setting must be set to "Quick Start" in the Device Setup menu.

  • Likewise if the player is turned off, it may not be discoverable by the Binding's discovery scan.

  • If the player is switched off when the binding first starts up or if power to the player is ever interrupted, up to 30 seconds may elapse before the binding begins to update when the player is switched on.

  • If you experience any issues using the binding, first ensure that the player's firmware is up to date with the latest available version (especially on the older models).

  • For the older models, some of the features in the control API were added after the players were shipped.

  • Available HDMI modes for BDP-83 & BDP-9x: AUTO, SRC, 1080P, 1080I, 720P, SDP, SDI

  • Available HDMI modes for BDP-10x: AUTO, SRC, 4K2K, 1080P, 1080I, 720P, SDP, SDI

  • Available HDMI modes for UDP-20x: AUTO, SRC, UHD_AUTO, UHD24, UHD50, UHD60, 1080P_AUTO, 1080P24, 1080P50, 1080P60, 1080I50, 1080I60, 720P50, 720P60, 567P, 567I, 480P, 480I

  • On Linux, you may get an error stating the serial port cannot be opened when the Oppo binding tries to load.

  • You can get around this by adding the openhab user to the dialout group like this: usermod -a -G dialout openhab.

  • Also on Linux you may have issues with the USB if using two serial USB devices e.g. Oppo and RFXcom.

  • See the general documentation about serial port configuration for more on symlinking the USB ports.

  • Here is an example of ser2net.conf (for ser2net version < 4) you can use to share your serial port /dev/ttyUSB0 on IP port 4444 using ser2net Linux tool (opens new window) (take care, the baud rate is specific to the Oppo player):

4444:raw:0:/dev/ttyUSB0:9600 8DATABITS NONE 1STOPBIT LOCAL
  • Here is an example of ser2net.yaml (for ser2net version >= 4) you can use to share your serial port /dev/ttyUSB0 on IP port 4444 using ser2net Linux tool (opens new window) (take care, the baud rate is specific to the Oppo player):
connection: &conOppo
    accepter: tcp,4444
    enable: on
    options:
      kickolduser: true
    connector: serialdev,
              /dev/ttyUSB0,
              9600n81,local

# Channels

The following channels are available:

Channel ID Item Type Description
power Switch Turn the power for the player on or off
volume Dimmer Control the volume for the player (0-100%)
mute Switch Mute or unmute the volume on the player
source Number Select the source input for the player (0-6; number of available options varies by model)
play_mode String Indicates the current playback mode of the player (ReadOnly)
control Player Simulate pressing the transport control buttons on the remote control (play/pause/next/previous/rew/ffwd)
time_mode String Sets the time information display mode on the player (T= Title Elapsed, X= Title Remaining, C= Chapter Elapsed, K= Chapter Remaining)
time_display Number:Time The playback time elapsed/remaining in seconds (ReadOnly)
current_title Number The current title or track number playing (ReadOnly)
total_title Number The total number of titles or tracks on the disc (ReadOnly)
current_chapter Number The current chapter number player (ReadOnly)
total_chapter Number The total number of chapters in the current title (ReadOnly)
repeat_mode String Sets the current repeat mode (00-06)
zoom_mode String Sets the current zoom mode (00-12)
disc_type String The current type of disc in the player (ReadOnly)
audio_type String The current audio track type (ReadOnly)
subtitle_type String The current subtitle selected (ReadOnly)
aspect_ratio String The aspect ratio of the current video output [UDP-203/205 only] (ReadOnly)
source_resolution String The video resolution of the content being played (ReadOnly)
output_resolution String The video resolution of the player output (ReadOnly)
3d_indicator String Indicates if the content playing is 2D or 3D (ReadOnly)
osd_position Number Sets the OSD position (0 to 5) [10x models and up]
sub_shift Number Sets the subtitle shift (-10 to 10) [10x models and up] (note more than 5 from 0 throws an error on the BDP103)
hdmi_mode String Sets the current HDMI output mode (options vary by model; see notes above for allowed values)
hdr_mode String Sets current HDR output mode (Auto, On, Off) [UDP-203/205 only]
remote_button String Simulate pressing a button on the remote control [3 letter code; codes can be found in Appendix A below] (WriteOnly)

# Full Example

oppo.things:

// direct IP connection
oppo:player:myoppo "Oppo Blu-ray" [ host="192.168.0.10", model=103, verboseMode=false]

// direct serial connection
oppo:player:myoppo "Oppo Blu-ray" [ serialPort="COM5", model=103, verboseMode=true]

// serial over IP connection
oppo:player:myoppo "Oppo Blu-ray" [ host="192.168.0.9", port=4444, model=103, verboseMode=true]

oppo.items:

Switch oppo_power "Power" { channel="oppo:player:myoppo:power" }
Dimmer oppo_volume "Volume [%d %%]" { channel="oppo:player:myoppo:volume" }
Switch oppo_mute "Mute" { channel="oppo:player:myoppo:mute" }
Number oppo_source "Source Input [%s]" { channel="oppo:player:myoppo:source" }
String oppo_play_mode "Play Mode [%s]" { channel="oppo:player:myoppo:play_mode" }
Player oppo_control "Control" { channel="oppo:player:myoppo:control" }
String oppo_time_mode "Time Mode [%s]" { channel="oppo:player:myoppo:time_mode" }
Number:Time oppo_time_display "Time [JS(secondsformat.js):%s]" { channel="oppo:player:myoppo:time_display" }
Number oppo_current_title "Current Title/Track [%s]" { channel="oppo:player:myoppo:current_title" }
Number oppo_total_title "Total Title/Track [%s]" { channel="oppo:player:myoppo:total_title" }
Number oppo_current_chapter "Current Chapter [%s]" { channel="oppo:player:myoppo:current_chapter" }
Number oppo_total_chapter "Total Chapter [%s]" { channel="oppo:player:myoppo:total_chapter" }
String oppo_repeat_mode "Repeat Mode [%s]" { channel="oppo:player:myoppo:repeat_mode" }
String oppo_zoom_mode "Zoom Mode [%s]" { channel="oppo:player:myoppo:zoom_mode" }
String oppo_disc_type "Disc Type [%s]" { channel="oppo:player:myoppo:disc_type" }
String oppo_audio_type "Audio Type [%s]" { channel="oppo:player:myoppo:audio_type" }
String oppo_subtitle_type "Subtitle Type [%s]" { channel="oppo:player:myoppo:subtitle_type" }
String oppo_aspect_ratio "Aspect Ratio [%s]" { channel="oppo:player:myoppo:aspect_ratio" }
String oppo_source_resolution "Source Resolution [%s]" { channel="oppo:player:myoppo:source_resolution" }
String oppo_output_resolution "Output Resolution [%s]" { channel="oppo:player:myoppo:output_resolution" }
String oppo_3d_indicator "3D/2D Indicator [%s]" { channel="oppo:player:myoppo:3d_indicator" }
Number oppo_osd_position "OSD Position [%s]" { channel="oppo:player:myoppo:osd_position" }
Number oppo_sub_shift "Subtitle Shift [%s]" { channel="oppo:player:myoppo:sub_shift" }
String oppo_hdmi_mode "HDMI Mode [%s]" { channel="oppo:player:myoppo:hdmi_mode" }
String oppo_hdr_mode "HDR Mode [%s]" { channel="oppo:player:myoppo:hdr_mode" }
String oppo_remote_button "Remote Button [%s]" { channel="oppo:player:myoppo:remote_button" }

secondsformat.js:

(function(timestamp) {
    var totalSeconds = Date.parse(timestamp) / 1000

    if (isNaN(totalSeconds)) {
        return '-';
    } else {
        hours = Math.floor(totalSeconds / 3600);
        totalSeconds %= 3600;
        minutes = Math.floor(totalSeconds / 60);
        seconds = totalSeconds % 60;
        if ( hours < 10 ) {
            hours = '0' + hours;
        }
        if ( minutes < 10 ) {
            minutes = '0' + minutes;
        }
        if ( seconds < 10 ) {
            seconds = '0' + seconds;
        }
        return hours + ':' + minutes + ':' + seconds;
    }
})(input)

oppo.sitemap:

sitemap oppo label="Oppo Blu-ray" {
    Frame label="Player"    {
        Switch item=oppo_power
        // Volume can be a Setpoint also
        Slider item=oppo_volume minValue=0 maxValue=100 step=1 visibility=[oppo_power==ON] icon="soundvolume"
        Switch item=oppo_mute visibility=[oppo_power==ON] icon="soundvolume_mute"
        Selection item=oppo_source visibility=[oppo_power==ON] icon="player"
        Text item=oppo_play_mode visibility=[oppo_power==ON] icon="zoom"
        Default item=oppo_control visibility=[oppo_power==ON]
        Selection item=oppo_time_mode visibility=[oppo_power==ON] icon="time"
        Text item=oppo_time_display visibility=[oppo_power==ON] icon="time"
        Text item=oppo_current_title visibility=[oppo_power==ON] icon="zoom"
        Text item=oppo_total_title visibility=[oppo_power==ON] icon="zoom"
        Text item=oppo_current_chapter visibility=[oppo_power==ON] icon="zoom"
        Text item=oppo_total_chapter visibility=[oppo_power==ON] icon="zoom"
        Selection item=oppo_repeat_mode visibility=[oppo_power==ON] icon="none"
        Selection item=oppo_zoom_mode visibility=[oppo_power==ON] icon="none"
        Text item=oppo_disc_type visibility=[oppo_power==ON] icon="none"
        Text item=oppo_audio_type visibility=[oppo_power==ON] icon="none"
        Text item=oppo_subtitle_type visibility=[oppo_power==ON] icon="none"
        Text item=oppo_aspect_ratio visibility=[oppo_power==ON] icon="none"
        Text item=oppo_source_resolution visibility=[oppo_power==ON] icon="video"
        Text item=oppo_output_resolution visibility=[oppo_power==ON] icon="video"
        Text item=oppo_3d_indicator visibility=[oppo_power==ON] icon="none"
        Setpoint item=oppo_osd_position label="OSD Position [%d]" minValue=0 maxValue=5 step=1 visibility=[oppo_power==ON]
        Setpoint item=oppo_sub_shift label="Sub Title Shift [%d]" minValue=-10 maxValue=10 step=1 visibility=[oppo_power==ON]
        Selection item=oppo_hdmi_mode visibility=[oppo_power==ON] icon="video"
        Selection item=oppo_hdr_mode visibility=[oppo_power==ON] icon="colorwheel"
        // This Selection is deprecated in favor of the Buttongrid element below
        Selection item=oppo_remote_button visibility=[oppo_power==ON]
        Buttongrid label="Remote Control" staticIcon=material:tv_remote item=oppo_remote_button buttons=[1:1:POW="Power"=switch-off, 1:3:SRC="Input", 1:4:EJT="Open"=f7:eject, 2:2:NFX="Netflix", 2:3:VDU="Vudu", 3:1:PUR="Pure Audio", 3:2:VDN="Volume -", 3:3:VUP="Volume +", 3:4:MUT="Mute"=soundvolume_mute, 4:1:NU1="1", 4:2:NU2="2", 4:3:NU3="3", 4:4:HOM="Home"=f7:house, 5:1:NU4="4", 5:2:NU5="5", 5:3:NU6="6", 5:4:PUP="Page Up", 6:1:NU7="7", 6:2:NU8="8", 6:3:NU9="9", 6:4:PDN="Page Down", 7:1:CLR="Clear", 7:2:NU0="0", 7:3:GOT="Goto", 7:4:OSD="Info", 8:1:TTL="Top Menu", 8:2:NUP="Up"=f7:arrowtriangle_up, 8:3:MNU="Pop-Up Menu", 9:1:NLT="Left"=f7:arrowtriangle_left, 9:2:SEL="Enter", 9:3:NRT="Right"=f7:arrowtriangle_right, 10:1:OPT="Option", 10:2:NDN="Down"=f7:arrowtriangle_down, 10:3:RET="Return", 11:1:RED="Red", 11:2:GRN="Green", 11:3:BLU="Blue", 11:4:YLW="Yellow", 12:1:STP="Stop"=f7:stop, 12:2:PLA="Play"=f7:play, 12:3:PAU="Pause"=f7:pause, 13:1:PRE="Prev"=f7:backward_end_alt, 13:2:REV="Rev"=f7:backward, 13:3:FWD="Fwd"=f7:forward, 13:4:NXT="Next"=f7:forward_end_alt, 14:1:AUD="Audio", 14:2:SUB="Subtitle", 14:3:ZOM="Zoom", 14:4:M3D="3D", 15:1:SET="Setup", 15:2:ATB="AB Replay", 15:3:RPT="Repeat", 15:4:DIM="Dimmer", 16:1:HDM="Resolution", 16:2:SEH="Picture", 16:3:INH="Detail Info", 16:4:HDR="HDR"]
    }
}

# Appendix A - 'remote_button' codes

Command Function
POW Toggle power ON and OFF
SRC Select input source
EJT Open/close the disc tray
PON Discrete on
POF Discrete off
SYS Switch output TV system (PAL/NTSC/MULTI)
DIM Dim front panel display
PUR Pure audio mode (no video)
VUP Increase volume
VDN Decrease volume
MUT Mute/Unmute audio
NU1 Numeric key 1
NU2 Numeric key 2
NU3 Numeric key 3
NU4 Numeric key 4
NU5 Numeric key 5
NU6 Numeric key 6
NU7 Numeric key 7
NU8 Numeric key 8
NU9 Numeric key 9
NU0 Numeric key 0
CLR Clear numeric input
GOT Play from a specified location
HOM Go to Home Menu to select media source
PUP Show previous page
PDN Show next page
OSD Show/hide on-screen display
TTL Show BD top menu or DVD title menu
MNU Show BD pop-up menu or DVD menu
NUP Up Arrow Navigation
NLT Left Arrow Navigation
NRT Right Arrow Navigation
NDN Down Arrow Navigation
SEL ENTER Navigation
SET Enter the player setup menu
RET Return to the previous menu or mode
RED RED Function varies by content
GRN GREEN Function varies by content
BLU BLUE Function varies by content
YLW YELLOW Function varies by content
STP Stop playback
PLA Start playback
PAU Pause playback
PRE Skip to previous
REV Fast reverse play
FWD Fast forward play
NXT Skip to next
AUD Change audio language or channel
SUB Change subtitle language
ANG Change camera angle
ZOM Zoom in/out and adjust aspect ratio
SAP Turn on/off Secondary Audio Program
ATB AB Repeat play the selected section
RPT Repeat play
PIP Show/hide Picture-in-Picture
HDM Switch output resolution
SUH Press and hold the SUBTITLE key. This activates the subtitle shift feature.
NFX Stop current playback and start the Netflix application
VDU Stop current playback and start the VUDU application
OPT Show/hide the Option menu
M3D 3D Show/hide the 2D-to-3D Conversion or 3D adjustment menu
SEH Display the Picture Adjustment menu
DRB Display the Darbee Adjustment menu

# Extra buttons on UDP models

Command Function
HDR Display the HDR selection menu
INH Show on-screen detailed information
RLH Set resolution to Auto
AVS Display the A/V Sync adjustment menu
GPA Gapless Play. This functions the same as selecting Gapless Play in the Option Menu.