Skip to content

Using multiple screens

This section covers using multiple displays and screens.

Distinction between displays, windows and screens

The MPF media controller knows windows and displays. A window is the window where MPF-MC pops up on your desktop using kivy. Internally, MPF can have multiple displays which are internal viewports and can be targeted by slides. A display can either be displayed on a window or on one or more DMDs. Additionally, a display can also show one or more other displays using display widgets. MPF does not know about screens which are phyiscal monitors connected to your machine. However, the kivy window can span multiple screens.

Using multiple screens on your PC

Some machines use more than one screen. Unfortunately, kivy (the graphics framework we use) does only support one screen and cannot easily be started two times. This is mostly caused by OpenGL which is rarely used to render multiple windows. The simplest solution to this problem is to extend the MC window to span both (or more) screens. This can be achieved using the following config:

kivy_config:
  kivy:
    desktop: 1
    exit_on_escape: true
    pause_on_minimize: 0
    log_dir:
    window_icon:
  graphics:
    borderless: true
    window_state: visible # visible, hidden, maximized, minimized
    fbo: hardware # hardware, software, force-hardware
    fullscreen: false
    left: 0
    top: 0
    width: 3840   # width of display1 + display2
    height: 1080  # common height (or the maximum of both)
    maxfps: 30
    multisamples: 2
    position: custom # auto, custom
    show_cursor: true
    resizable: false
    rotation: 0
displays:
  display1:
    width: 1920
    height: 1080
  display2:
    width: 1920
    height: 1080
  combined_display:
    width: 3840
    height: 1080
slides:
  base_slide:
    - type: display
      source_display: display1
      width: 1920
      height: 1080
      x: left
      anchor_x: left
    - type: display
      source_display: display2
      width: 1920
      height: 1080
      x: right
      anchor_x: right
slide_player:
  mc_ready:
    base_slide:
      target: combined_display
##! test
#! advance_time_and_run .1
#! assert_slide_on_top base_slide combined_display

Use width and height to set the size of the window. left and top are used to position the window.

We created one window which spans both screens. Then we define a display combined_display which will be displayed on startup by the slide base_slide spanning both screens. base_slide contains two widgets which show the displays display1 and display2. You can now target any slides to those two displays. See display widget for details.

Using multiple displays

You can easily use two DMDs and one LCD (or two LCDs with the solution above). To implement that you need to define multiple displays. One diplay per DMD and one for your LCD. If you want to show your DMDs on the LCD (i.e. during development) you can also define a fourth display and create a slide which contains three display widgets to show the other three displays.


Something missing or wrong? You can fix it!

This website is edited by people like you! Is something wrong or missing? Is something out of date, or can you explain it better?

Please help us! You can fix it yourself and be an official "open source" contributor!

It's easy! See our Beginner's guide to editing the docs.

Page navigation via the keyboard: < >

You can navigate this site via the keyboard. There are two modes:

General navigation, when search is not focused:

  • F , S , / : open search dialog
  • P , , : go to previous page
  • N , . : go to next page

While using the search function:

  • Down , Up : select next / previous result
  • Esc , Tab : close search
  • Enter : go to highlighted page in the results