Appendix II.
Estimated reading time: 13 minutes
This zip archive contains settings, icon images and other content for customizing the UI design of BM1 Display.
Zip the “custom” folder in the following configuration as “custom.zip”. (When zipping, include the “custom” folder. The “custom” folder must be generated when unzipping the zipped folder.)
custom/
i18n/
locale*.json
images/
*.{png,jpg}
style/
style.css
fonts/
*.{woff2,woff,eot,ttf,svg}
custom.json
locale.json (optional)
You can customize all UI messages. Program messages are written in the following JSON formats:
- Files named locale-<language name>.json, are used when the language in the filen ame matches the language setting on BRAVIA.
- Specify the “language name” section in ISO 639-1 format. Example)
locale-en.json, locale-ja.json
- Specify the “language name” section in ISO 639-1 format. Example)
- Files named locale.json, are used when the corresponding message is not included in the locale-<language name>.json file.
- locale-<language name>.json messages have higher priority than locale.json messages.
- When messages are not set in locale-<language name>.json or locale.json format, default messages are used.
{
"COMMON":{
"MESSAGE_AUTH_ERROR":"Please confirm authentication of IP control",
"BUTTON_OK":"OK",
"BUTTON_CANCEL":"Cancel",
"BUTTON_BACK":"Back",
"BUTTON_CLOSE": "Close",
"LABEL_PASSCODE":"Passcode",
"LABEL_PASSCODE_DELIMITER":":",
"MENU_GUIDE": "Touch the bar to open Menu",
"LOADING" : "Loading..."
},
"HOME":{
"BUTTON_HOME":"HOME",
"BUTTON_INPUTS":"Input",
"BUTTON_PRESENTATION_TIMER":"Presentation Timer",
"BUTTON_VC":"Video Conference",
"BUTTON_ANNOTATION":"Annotation",
"BUTTON_HELP":"Help"
},
"END_ALARM": {
"MESSAGE_FINISH_BEFORE_15_MIN":" 15 min left",
"MESSAGE_FINISH_BEFORE_5_MIN":" 5 min left",
"MESSAGE_FINISH":" End time"
},
"PRESENTATION_TIMER":{
"MESSAGE_TIMEOUT":" Presentation time is up.",
"LABEL_PRESENTATION_TIME":"Presentation Time",
"LABEL_MINUTES":"min."
},
"ANNOTATION":{
"MESSAGE_CONFIRM_CLOSE":"Are you sure to quit annotation mode?",
"MESSAGE_CONFIRM_SAVE":"Are you sure to save screen data on USB storage?",
"MESSAGE_SAVE":"Successfully saved.",
"MESSAGE_SAVE_ERROR":"Failed to save.",
"MESSAGE_SAVE_ERROR_FORBIDDEN": "Saving is not allowed."
},
"VC":{
"BUTTON_VIDEO_AUDIO": "Join with Video & Audio",
"BUTTON_AUDIO_ONLY": "Join with Audio Only",
"BUTTON_MIC": "Mic",
"BUTTON_ANNOTATION": "Annotation",
"BUTTON_LAYOUT": "Layout",
"BUTTON_EXIT": "Exit",
"LABEL_ACCESS_CODE": "Access Code:",
"LABEL_DISPLAY": "Display",
"MESSAGE_ENTER_ACCESS_CODE":"Enter the access code.",
"MESSAGE_WAITING":"Waiting...",
"MESSAGE_CONNECTING":"Connecting...",
"MESSAGE_CONFIRM_EXIT": "Are you sure you want to exit the video conference?",
"MESSAGE_SHARING_SCREEN": "You are sharing the screen.",
"MESSAGE_CHECKING_USB_DEVICE": "Checking USB camera or microphone...",
"MESSAGE_CLOSED": "The video conference has closed.",
"MESSAGE_DISPLAY_CONSTRAINTS": "No video due to display performance restriction.",
"ERROR_MESSAGE_SETTING_DISABLED": "The video conference setting is disabled.",
"ERROR_MESSAGE_NO_DEVICE": "USB camera or microphone is not connected.",
"ERROR_MESSAGE_INVALID_DEVICE" : "USB camera or microphone is not available.",
"ERROR_MESSAGE_SERVER_CONNECT": "Failed to connect to the server. Please check the network connection of the display.",
"ERROR_MESSAGE_INVALID_ACCESS_CODE": "Invalid access code. Please try again.",
"ERROR_MESSAGE_ROOM_IS_FULL": "The video conference is full",
"ERROR_MESSAGE_P2P_CONNECT": "Failed to connect to the video conference.",
"ERROR_MESSAGE_P2P_TIMEOUT": "Failed to connect to the video conference.",
"ERROR_MESSAGE_P2P_CLOSED": "Connection closed.",
"ERROR_MESSAGE_GENERIC": "Error occurred."
},
"HELP": {
"DIALOG_HEADER":"Help",
"ITEM_LABEL_HDMI":"External input switching",
"ITEM_LABEL_PRESENTATION_TIMER":"Presentation timer [Red Button]",
"ITEM_LABEL_ANNOTATION":"Annotation [Green Button]",
"ITEM_LABEL_VC":"Video conference [Yellow Button]",
"ITEM_LABEL_STATUSBAR":"Status bar",
"ITEM_LABEL_HELP_INFO": "About this application",
"LABEL_IP":"IP address",
"LABEL_VERSION":"Version",
"LABEL_LICENSES":"Open source licenses",
"MESSAGE_HDMI":"Switching the external input automatically by connecting HDMI. You can also manually switch to HDMI 1 - 4 by the input menu or pushing [1] - [4] button.",
"MESSAGE_PRESENTATION_TIMER":"Sets the timer to count down. This is useful when the discussion time for topics is predetermined.",
"MESSAGE_ANNOTATION":"Draws annotation overlaying a connected external input, or uses the screen as a whiteboard without external inputs. You can also download the content you drew to your PC or save it to a USB storage.",
"MESSAGE_VC":"Joins the video conference by entering the access code.",
"MESSAGE_STATUSBAR":"You can switch visibility of the status bar displayed in the top right corner of the screen by the [0] button of remote control. The status bar is always displayed on the HOME screen."
},
"SETTINGS":{
"DIALOG_HEADER": "Settings",
"ITEM_LABLE_SERVER_CONNECTION": "Server connection",
"ITEM_LABEL_SERVER_URL": "Server URL",
"ITEM_LABEL_HOME_SCREEN": "Home screen",
"ITEM_LABLE_TITLE": "Title",
"ITEM_LABEL_SUBTITLE": "Subtitle",
"ITEM_LABEL_CLOCK": "Clock",
"ITEM_LABEL_WEB_FRAME": "Web frame",
"ITEM_LABEL_FRAME_SIZE": "Frame size",
"ITEM_LABEL_URL": "URL",
"ITEM_LABEL_POWER": "Power",
"ITEM_LABEL_AUTO_POWER_OFF": "Auto power off",
"ITEM_LABEL_AUTO_REBOOT": "Auto reboot",
"ITEM_LABEL_INPUTS": "Inputs",
"ITEM_LABEL_INPUTS_DISPLAY_NAME": "Display name",
"ITEM_LABEL_INPUTS_HDMI1": "HDMI 1",
"ITEM_LABEL_INPUTS_HDMI2": "HDMI 2",
"ITEM_LABEL_INPUTS_HDMI3": "HDMI 3",
"ITEM_LABEL_INPUTS_HDMI4": "HDMI 4",
"ITEM_LABEL_HELP_URL": "Help URL",
"ITEM_LABEL_ANNOTATION": "Annotation",
"ITEM_LABEL_CANVAS_COLOR": "Canvas color",
"ITEM_LABEL_SAVING_ANNOTATION_TO_USB_MEMORY": "Save annotation to USB storage device",
"ITEM_LABEL_SETTINGS_LOCK": "Settings lock",
"ITEM_LABEL_LOCK": "Lock",
"ITEM_LABEL_PINCODE": "PIN code",
"ITEM_VALUE_ON": "On",
"ITEM_VALUE_OFF": "Off",
"ITEM_VALUE_FRAME_SIZE_NONE": "None",
"ITEM_VALUE_FRAME_SIZE_HALF": "Half",
"ITEM_VALUE_FRAME_SIZE_FULL": "Full",
"ITEM_VALUE_AUTO_POWER_OFF_MIN": " min",
"ITEM_VALUE_CANVAS_COLOR_WHITE": "White",
"ITEM_VALUE_CANVAS_COLOR_BLACK": "Black",
"MESSAGE_CONFIRM_IMPORTING": "A USB storage device with valid data to import has been detected. Do you want to import this data?",
"MESSAGE_IMPORTING": "Importing... \nDo not remove USB storage device.",
"MESSAGE_IMPORTING_COMPLETED": "Import completed successfully. You can remove the USB storage device.",
"MESSAGE_IMPORTING_ERROR_FORMAT": "Failed to import. Failed to parse .",
"MESSAGE_IMPORTING_ERROR_UNZIP": "Failed to import. Failed to extract .",
"MESSAGE_IMPORTING_ERROR_NOT_FOUND": "Failed to import. is required.",
"MESSAGE_IMPORTING_ERROR_COPY": "Failed to import. Failed to copy .",
"MESSAGE_IMPORTING_ERROR_IN_PROGRESS": "Import is in progress. Please retry later.",
"MESSAGE_IMPORTING_ERROR": "Failed to import.",
"MESSAGE_PINCODE_ENTER": "Enter PIN code.",
"MESSAGE_PINCODE_INCORRECT": "PIN code is incorrect. Enter PIN code.",
"BUTTON_IMPORT_OK": "Import"
},
"TIME_SETTINGS":{
"DIALOG_HEADER":"Set current date & time"
},
"NOTIFICATION": {
"MESSAGE_REBOOT_1MIN": "Display will reboot in 1 minute.",
"MESSAGE_REBOOT_NOW": "Display rebooting.",
"MESSAGE_AUTO_POWER_OFF": "Powering off due to inactivity.",
"MESSAGE_POWEROFF_NOW": "Powering off.",
"MESSAGE_VC_JOINED": " has joined.",
"MESSAGE_VC_LEFT": " has left.",
"MESSAGE_VC_MIRRORING_SHARED": " has started screen sharing.",
"MESSAGE_VC_ANNOTATION_SHARED": "Started screen sharing."
}
}
images (opional)
You can customize all UI icon images.
Image files with the specified file names are placed in the “images” folder. The file names and resolution of each icon are as follows.
Place | Icon | File name | Default resolution |
---|---|---|---|
HOME | Screenshot not allowed | icon-home-meshot_ban.png | 48x48 |
Menu | Input | icon-menu-inputr.png | 72x72 |
Menu | Presentation Timer | icon-menu-timer.png | 72x72 |
Menu | Annotation | icon-menu-annotation.png | 72x72 |
Menu | Video Conference | icon-menu-vc.png | 72x72 |
Menu | Help | icon-menu-help.png | 72x72 |
Menu | Current Input | icon-menu-current_input.png | 24x24 |
Menu | Current Input (Focused) | icon-menu-current_input_focused.png | 24x24 |
Menu | Guide Arrow | icon-menu-guide_arrow.png | 48x48 |
Menu | Arrow Up | icon-menu-arrow_up.png | 48x48 |
Menu | Arrow Down | icon-menu-arrow_down.png | 48x48 |
Annotation | Close | icon-annotation-close.png | 72x72 |
Annotation | Mouse Mode | icon-annotation-mouse_mode.png | 72x72 |
Annotation | Touch Mode | icon-annotation-touch_mode.png | 72x72 |
Annotation | Clear | icon-annotation-clear.png | 72x72 |
Annotation | Undo | icon-annotation-undo.png | 72x72 |
Annotation | Redo | icon-annotation-redo.png | 72x72 |
Annotation | Eraser | icon-annotation-eraser.png | 72x72 |
Annotation | Pen - Red | icon-annotation-pen_red.png | 72x72 |
Annotation | Pen - Blue | icon-annotation-pen_blue.png | 72x72 |
Annotation | Pen - Green | icon-annotation-pen_green.png | 72x72 |
Annotation | Pen - Yellow | icon-annotation-pen_yellow.png | 72x72 |
Annotation | Pen - Purple | icon-annotation-pen_purple.png | 72x72 |
Annotation | Pen - Orange | icon-annotation-pen_orange.png | 72x72 |
Annotation | Pen - White | icon-annotation-pen_white.png | 72x72 |
Annotation | Pen - Black | icon-annotation-pen_black.png | 72x72 |
Annotation | Palette - Red | icon-annotation-palette_red.png | 50x50 |
Annotation | Palette - Blue | icon-annotation-palette_blue.png | 50x50 |
Annotation | Palette - Green | icon-annotation-palette_green.png | 50x50 |
Annotation | Palette - Yellow | icon-annotation-palette_yellow.png | 50x50 |
Annotation | Palette - Purple | icon-annotation-palette_purple.png | 50x50 |
Annotation | Palette - Orange | icon-annotation-palette_orange.png | 50x50 |
Annotation | Palette - White | icon-annotation-palette_white.png | 50x50 |
Annotation | Palette - Black | icon-annotation-palette_black.png | 50x50 |
Annotation | Save | icon-annotation-save.png | 72x72 |
Annotation | Remote Pointer | icon-mytouch-pointer.png | 64x64 |
Video Conference Menu | Mic ON | icon-vc_menu-mic_on.png | 64x64 |
Video Conference Menu | Mic OFF | icon-vc_menu-mic_off.png | 64x64 |
Video Conference Menu | Layout | icon-vc_menu-layout.png | 64x64 |
Video Conference Menu | Exit | icon-vc_menu-exit.png | 64x64 |
Video Conference | Mic ON | icon-vc-mic_on.png | 48x48 |
Video Conference | Mic OFF | icon-vc-mic_off.png | 48x48 |
Video Conference | Person Large | icon-vc-person_l.png | 720x720 |
Video Conference | Person Small | icon-vc-person_s.png | 180x180 |
Notification | Presentation Timer | icon-notification-presentation_timer.png | 60x60 |
Notification | Information (i mark) | icon-notification-information.png | 60x60 |
Dialog | Arrow Up | icon-dialog-arrow_up.png | 48x48 |
Dialog | Arrow Down | icon-dialog-arrow_down.png | 48x48 |
Num Pad | Close | icon-vc-numpad_close.png | 72x72 |
Common | Loading | icon-common-loading.png | 48x48 |
style.css (optional)
You can customize the style (font, text color, text size, background color) of the main parts of the UI.
Write customization files in CSS file format. The classes of each customizable section are defined as follows.
Class name | Target | Recommended property | Note |
---|---|---|---|
.custom-font | All | font-family | Use @font-face to add font definition. |
.custom-menu-button | Menu button | background, font-size, collor | Use :focus class for focused. “!importand” is required. |
.custom-menu-guide | Menu guide | background, font-size, collor | |
.custom-dialog-body | Dialog body | background, font-size, color | |
.custom-dialog-button | Dialog button | background, font-size, color | Use :focus class for focused. “!important” is required. |
.custom-dialog-select | Dialog select box | background, font-size, color | Use :focus class for focused. “!important” is required. |
.custom-title-main | Title | background, font-size, color | |
.custom-title-sub | Subtitle | background, font-size, color | |
.custom-notification | Notification | background, font-size, color | |
.custom-statusbar | Statusbar | background, font-size, color, height | |
.custom-passcode | Passcode | background, font-size, color | |
.custom-clock | Clock | font-size, color | |
.custom-presentation-timer | Presentation timer | font-size, color | |
.custom-annotation-toolbar | Annotation toolbar | background | |
.custom-annotation-toolbar-item | Annotation toolbar item | border | Use :active class for selected. |
.custom-vc-background | Video conference background | background-color | “!important” is required. |
.custom-vc-sharing-message | Screen sharing message | background, font-size, color | “!important” is required. |
.custom-help | Help | background-color, color | “!important” is required. |
.custom-schedule | Shedule | background-color: #202124, top: 0, left: 1302px, width: 618px | |
.custom-schedule-item | Shedule item | background-color: #40688F, left: 128px, color: #F1F1F1, font-size: 28px | |
.custom-schedule-time-scale-label | Schedule time scale label | top: -12px, left: 45px, color: #EDEDED, font-size: 24px | |
.custom-schedule-time-scale-line | Schedule time scale line | left: 118px, border-top: solid 1px #999999 | |
.custom-schedule-current-time-line | Current timeline of schedule | left: 0px, border-top: solid 2px #51AAFF | |
.custom-schedule-past-rect-dimmer | Dimmer of past rectangle on schedule | background-color: rgba(33,33,33,0.7) |
Ex)
@font-face {
font-family: orangejuice;
src: url("../fonts/orangejuice2.0.ttf") format('truetype');
}
.custom-font {
font-family: orangejuice, serf;
}
.custom-menu {
background: #3e8f3e;
color: #204d74;
}
fonts (optional)
You can set any font file to the text to be used in the UI.
The default file is placed in the “fonts” file. Specify the font family in “style.css”.
custom.json (optional)
Write custom.json in JSON format. The formats are as follows:
- webFrame ... <object> (optional)
- top ... <number> (optional) WebFrame display X coordinate Default: 0
- left ... <number> (optional) WebFrame display Y coordinate Default: 0
- width ... <number> (optional) WebFrame display width Default: 1920
- height ... <number> (optional) WebFrame display height Default: 1080
- zoom ... <number> (optional) WebFrame enlargement ratio Default: 1.0
- clock ... <object> (optional)
- format ... <string> (mandatory) Format of home screen clock moment.js(https://momentjs.com/docs/) Compliant character string
- canvasColor ... <object> (optional)
- white ... <string> (optional) “White” canvas color, Default: “0xFFFFFFFF”
- black ... <string> (optional) “Black” canvas color, Default: “0x000000FF”
- version ... <number> (mandatory) Version of setting data. Specify “1” at all times.
Ex)
{
"webFrame": {
"top": 0,
"left": 0,
"width": 1920,
"height": 1080,
"zoom": 1.0
},
"clock": {
"format": "YYYY/MM/DD HH:mm:ss"
},
"canvasColor": {
"white": "0xFFFFFFFF",
"black": "0x000000FF"
},
"version": 1
}