/vDome

Multi-channel projection software designed for domes

Primary LanguageC++OtherNOASSERTION

vDome

Multi-channel projection software designed for domes. Provides real-time warping and slicing for domemaster input.

Developed by Charles Veasey for the Institute of Indian American Arts (IAIA).

##Overview

vDome is an application designed to calibrate multiple projectors on a hemispherical dome surface and display a domemaster formatted video, image, or interactive application. vDome also supports the play back of HD video files. vDome is generally used in two ways: 1) as a media player and 2) as a background process that listens to hardware/software input streams such as cameras, capture cards, and inter-application protocols such as Syphon, Spout, and Video4Linux.

As a media player vDome utilizes native os media libraries and accepts most common file formats and codecs of the operating system. In general:

  • Mac OS X: QuickTime, AV Foundation, HAP
  • Win 7/8: Windows Media Foundation, DirectShow, QuickTime, HAP
  • Linux: GStreamer

For optimized video playback, use the following codecs:

  • OS X: ProRes 422 and H.264
  • Windows 8.1: H.264 and WMF
  • Linux Ubuntu: H.264

To assist in media playback and creating playlists use the vDome Player interface: https://github.com/charlesveasey/vDome-player

Capture and camera inputs are hardware video stream solutions. A capture card is a flexible solution that allows one to run any application on the dome by sending the video output of one computer into another machine running vDome. With this, vDome essentially becomes the 2nd monitor on your production machine. Drag the After Effects or Unity preview window onto the dome and edit in real-time, play videos through your favorite media player: Quicktime, VLC, etc.

Syphon is a graphical interapplication protocol for OS X:
http://syphon.v002.info

Spout is a graphical interapplication protocol for Windows:
http://spout.zeal.co

Video4Linux is a graphical interapplication protocol for Linux:
http://en.wikipedia.org/wiki/Video4Linux

##Compiling ####All

####Mac

####Win

####Linux

  • Install openFrameworks dependencies, see INSTALL.md in openFrameworks linux package
  • Suggested IDE: Code::Blocks 10.04
  • Can also run make in root directory

##Installation ####Mac

####Win

####Linux

##Setup and Calibration Initial setup is done in XML (setting resolution, number of projectors, and input type). Calibration is done directly on the dome. For more information see the manual:
https://docs.google.com/document/d/1EHPpExjznFF6X0YTY5acLS0MNkEbtVFsLBCoJ2HHQlQ/edit#

##Supported

  • OS X 10.9
  • Windows 8.1
  • Linux Ubuntu 14

##Tested ####Mac

  • 10.8.x
  • 10.9.x

####Win

  • 7.x
  • 8.1.x

####Linux

  • Ubuntu 12.04
  • Ubuntu 14.04

##Future Development

  • Support for panorama
  • Auto-calibration via camera
  • Support for Nvidia Warp and Intensity API

Funding provided by the United States Department of Defence. Based on prior research from the University of New Mexico (UNM) and IAIA with funding provided by the National Science Foundation.

Thanks to research by the ARTS Labs at UNM and Paul Bourke at the University of Western Australia.