Display Media using MPCDI
BrightSign players support the MPCDI specification for warping and edge blending. This page outlines how to display media—including images, video, and HTML—using MPCDI. Note that some knowledge of BrightScript is required to develop MPCDI applications on BrightSign players.
The API described below requires firmware version 7.0 or later.
Support Overview
Player Models, MPCDI Levels, and MPCDI Version
Series 4 (XTx44, XDx34, HDx24) and Series 3 (XTx43, XDx33, HDx23, HO523) players support all levels of the MPCDI 2D Media profile.
The 4Kx42 players also support MPCDI, but at Level 1 and Level 2 only. We recommend Series 3 or 4 players for optimal rendering speeds.
MPCDI Version 1a is implemented on Series 3 and 4 players. It’s not supported on Series 5 players.
Media Types
MPCDI is supported with graphics objects such as roImageWidget, roHtmlWidget, and roTextWidget. It does not support the roVideoPlayer object; to apply MPCDI to a video, display the video as part of an HTML page.
BrightScript API for MPCDI
The BrightScript API is designed such that information corresponding to a particular region must be extracted from the .mpcdi file and then passed to the roVideoMode.SetMpcdi() method. Once the configuration information for a region is passed into the player, MPCDI is enabled, and media displayed in HTML, image, and text widgets will be warped according to the configuration.
Since the MPCDI configuration file might contain more than one region, the autorun script on the player will need to select a particular region from the .mpcdi file and parse the data for that region before using it to configure the player. Note that each player can display one MPCDI region only.
If you wish to bypass writing a script to parse MPCDI data and configure the player, you can use the template script attached to this page (see the MPCDI Template Script section below for more details).
Enabling MPCDI
To enable MPCDI, call the roVideoMode.SetMpcdi() method:
SetMpcdi(parameters As roAssociativeArray) As Boolean
Enables MPCDI using an associative array of parameters. This method returns true
if MPCDI has been enabled and false
if it could not be enabled. The associative array must contain the following parameters:
region
roAssociativeArray: An associative array of parameters containing region data:xresolution
int: The viewport width, which corresponds to the<XResolution>
attribute in the<region>
tag of the mpcdi.xml configuration fileyresolution
int: The viewport height, which corresponds to the<YResolution>
attribute in the<region>
tag of the mpcdi.xml configuration filex
float: The region coordinate horizontal position, which corresponds to the<x>
attribute in the<region>
tag of the mpcdi.xml configuration filey
float: The region coordinate vertical position, which corresponds to the<y>
attribute in the<region>
tag of the mpcdi.xml configuration filexsize
float: The region coordinate width, which corresponds to the<xsize>
attribute in the<region>
tag of the mpcdi.xml configuration fileysize
float: The region coordinate hieght, which corresponds to the<ysize>
attribute in the<region>
tag of the mpcdi.xml configuration file
blendmaps
roArray: An array containing one or two entries describing blend map data. The array must contain an entry describing alpha map parameters, and may contain a second entry describing beta map parameters. Each entry must have the following parameters:mapname
string: The map name, which can be either "alpha" or "beta"width
int: The map width, as provided in the map .png fileheight
int: The map height, as provided in the map .png filecomdepth
int: The number of components held in the map, which corresponds to the<alphaMap>
or<betaMap>
tag in the mpcdi.xml configuration filesize
int: The size of the decoded .png file data (in bytes)gammacorrection
float: The gamma correction value, which corresponds to the<gammaEmbedded>
attribute in the<alphaMap>
tag of the mpcid.xml configuration file (this setting does not apply to a beta map)data
roByteArray: The decoded .png data
warp
roAssociativeArray: An associative array of parameters containing warp data:width
int: The width of the geometry warp map, which is provided in the .pfm fileheight
int: The height of the geometry warp map, which is provied in the .pfm filedata
roArray: The extracted .pfm file data as an array of float values
Disabling MPCDI
To disable MPCDI, pass Invalid to the SetMpcdi()
method.
Example
vm = CreateObject("roVideoMode")
mpcdi_params = invalid
vm.SetMpcdi(mpcdi_params)
MPCDI Template Script
The .brs script attached to this page will extract all relevant data from an .mpcdi file and use it to configure MPCDI on the player. It then displays up to three HTML widgets: One widget can be used to display a video or image as a simple HTML page, while the other two display HTML pages from the web.
The Main()
function accepts an array of parameters:
[mpcdi_enabled, widget_count, filename.mpcdi, mode, ip_media_filename]
mpcdi_enabled
string: A flag that determines whether MPCDI is enabled ("on") or disabled ("off")widget_count
int: The number of widgets to display on screen (1, 2, or 3). If you specify a single widget, the image/video widget will be displayed as full screen.filename.mpcdi
string: The name of the .mpcdi filemode
string: The mode of the image/video widget ("image" or "video")ip_media_filename
string: The name of the media file to display in the image/video widget.
To modify the HTML pages displayed by the second and third widgets, change the SetUrl()
strings in the ShowUserWidgets()
function.
Setting MPCDI Regions
If you are using the template script attached to this page, you will need to assign each player to an MPCDI region before running the script. This is done by writing the region assignment to the player registry. The template script will retrieve the value from the registry and use it to extract the correct region data from the .mpcdi file.
You can write region assignments to the registry using the BrightSign Shell, or you can use BrightScript.
BrightSign Shell
Perform the following steps on each BrightSign player that is part of the MPCDI display:
Connect the player to a PC using a serial cable or Telnet/SSH.
Power off the player and remove the microSD card or other storage.
Power on the player.
Wait until the BrightSign splash screen appears on the display.
Depress the SVC button on the player. This will result in entry into the
BrightSign>
shell.Type "registry write brightscript mpcdi_region [region id]", where [region id] refers to the id attribute in the mpcdi.xml file associated with the region you wish to assign the player. Press Enter when finished.
Type "reboot" and press Enter.
If you later need to retrieve the region ID stored in the player registry, you can enter the following command into the shell: "registry read brightscript mpcdi_region"
BrightScript
Include the following in your autorun, plugin, or standalone script:
reg = CreateObject("roRegistrySection", "brightscript")
reg.write("mpcdi_region","region id")
The "region id" refers to the id
attribute in the mpcdi.xml file associated with the region you wish to assign the player. If this code is part of an autorun, you will need to develop a mechanism to differentiate among players and assign the correct region ID automatically.
You will also need to reboot the player at some point (for example, by calling RebootSystem()
) before displaying MPCDI so that the registry write goes into effect.
If you later need to retrieve the region ID stored in the player registry, you can call the roRegistrySection.Read() method.