Interactive Camera-Projector System

From MMVLWiki

Developed by Juan Roldan, ERASMUS exchange student from Cordoba, Spain
Enlarge
Developed by Juan Roldan, ERASMUS exchange student from Cordoba, Spain
Ushakiran Soutapalli, MSc student at Sheffield Hallam worked on the graphical user-interface
Enlarge
Ushakiran Soutapalli, MSc student at Sheffield Hallam worked on the graphical user-interface
Table of contents

Camera-Projector System

Application

mando (https://mando.sourceforge.net/) (or kmando) is a human computer interface using a camera and a projector. It was developed by Juan Roldan (prototype), Ushakiran Soutapalli (user interface), Julien Faucher (calibration), Jan Wedekind (technical supervision), and Claudia Amico (artwork) at the Mobile Machines and Vision Laboratory (MMVL) at Sheffield Hallam University, UK (https://www.shu.ac.uk).

The software makes use of a Video for Linux version 1 (V4L) camera such as the Logitech Quickcam Pro 4000 (https://www.qbik.ch/usb/devices/showdev.php?id=3332) 640x480 webcam (see exploits.org/v4l (https://www.exploits.org/v4l/) and qbik.ch (https://www.qbik.ch/usb/devices/) for compatible USB devices). The camera is calibrated against a standard projector screen and then used to determine the position of physical pointer (e.g. a pen) which is then used to virtually move the X11 pointer. Point-and-click functionality has also been implemented. The software now also supports IIDC/DCAM compatible firewire digital cameras such as the Unibrain Fire-i (https://damien.douxchamps.net/ieee1394/cameras/) (see Damien Douxchamps list (https://damien.douxchamps.net/ieee1394/cameras/) for cameras with IIDC=yes/1.30/1.31). Note that Video for Linux version 2 (V4L2) currently is not supported by mando.

The required parts of the Mimas real-time computer vision toolkit are included in the package.

How it works

Detection

The detection is a simple colour-segmentation using a thresholded colour-histogram. Therefore you need to use a marker pen or some other object with a distinct colour. The colour should not appear on the screen itself. If the colour of the pen will change due to different illumination conditions, you need to capture these colours when taking the reference image.

Mouse clicks

The standard deviation (https://en.wikipedia.org/wiki/Standard_deviation) of a few recent mouse-positions is used as a criterion, wether the mouse is stationary or moving. If the mouse is stationary, a mouse click is issued.

Design

UML-diagram of static structure
Enlarge
UML-diagram of static structure
UML-diagram showing collaboration of classes
Enlarge
UML-diagram showing collaboration of classes

Changelog

2008-02-07 version 1.6

  • Added more confusing array operator methods to keep up with the GCC freaks.

2007-03-27 version 1.5

  • Adding support for firewire digital camera
  • image_v4linput.cc: Accepting YUV422 (assuming it is same as UYVY).
  • Wizard has new combo-box for selecting video mode (PAL/NTSC/SECAM/AUTO)
  • image_v4linput.cc: Not preferring RGB support of camera. Prefer UYVY or YUV420p instead.

2007-04-14 version 1.4

  • Added spin-box for selecting camera channel.
  • GUI now has sliders for adjusting brightness, contrast, and others.

2007-03-27 version 1.3

  • Added some explanation about capturing reference image.
  • Distorted e-mails because of spam.

2007-02-12 version 1.2

  • configure.ac: Configure script must not use Qt3-moc.

2007-02-11 version 1.1

  • Makefile.am: Added moc-, qrc-, and uic-files to clean-rule.
  • configure.ac: Call "make clean" to delete built sources.

2007-02-02 version 1.0

  • Applications seems to run stable now -> releasing version 1.0

2006-10-20 version 0.6

  • Minor fixes on configure-script

2006-10-20 version 0.5

  • Fixed the check for gfortran (using AC_PROG_FC now). Thanks to Steven G. Johnson!
# On the older Mandriva version you may have to configure using
./configure FLIBS="-lgfortran"
# On openSuSE 10.0 libgfortranbegin.a was compiled without "-fPIC". You need to configure using
./configure F77=gfortran FLIBS="-lgfortran"

2006-10-17 version 0.4

  • Added support for UYVY-cameras.

2006-10-16 version 0.3

  • Video display can be zoomed using the mouse-wheel.
  • Display error-messages when accessing camera fails.

2006-10-13 version 0.2

  • Removed dependency on ImageMagick.

Downloads

Download the latest release mando-*.tar.bz2 from the mando download section at Sourceforge (https://sourceforge.net/project/platformdownload.php?group_id=220882). For your convenience the required parts of Mimas are included in the package. To build and run the package do

tar xjf mando-*.tar.bz2
cd mando-*
./configure
make
./mando


Donnie Bhayangkara (https://kde-apps.org/usermanager/search.php?username=pupil) has built a package for openSuSE 10.3 which can be downloaded here https://software.opensuse.org/search?baseproject=openSUSE%3A10.3&p=1&q=mando

Git Repository

The git repository can be accessed as follows

git clone git://mando.git.sourceforge.net/gitroot/mando mando

Gallery

Accessing the KDE-menu using the system (2.72 MByte video (https://vision.eng.shu.ac.uk/jan/kde-menu.avi))
Enlarge
Accessing the KDE-menu using the system (2.72 MByte video (https://vision.eng.shu.ac.uk/jan/kde-menu.avi))
Artist's impression of the system
Enlarge
Artist's impression of the system
Interactive camera-projector system
Enlarge
Interactive camera-projector system
Long demonstration of the prototype-system (11.4 MByte video (https://vision.eng.shu.ac.uk/jan/interactive.avi))
Enlarge
Long demonstration of the prototype-system (11.4 MByte video (https://vision.eng.shu.ac.uk/jan/interactive.avi))
Short interactive slides presentation with the system (6.3 MByte video (https://vision.eng.shu.ac.uk/jan/slides.avi))
Enlarge
Short interactive slides presentation with the system (6.3 MByte video (https://vision.eng.shu.ac.uk/jan/slides.avi))
Browsing the file-system and trying to play minigolf (14.4 MByte video (https://vision.eng.shu.ac.uk/jan/minigolf.avi))
Enlarge
Browsing the file-system and trying to play minigolf (14.4 MByte video (https://vision.eng.shu.ac.uk/jan/minigolf.avi))
Calibration of the screen using projected patterns
Enlarge
Calibration of the screen using projected patterns
Prototype of early user-interface (13.7 MByte video (https://vision.eng.shu.ac.uk/jan/interactive2.avi))
Enlarge
Prototype of early user-interface (13.7 MByte video (https://vision.eng.shu.ac.uk/jan/interactive2.avi))
Screenshot of the wizard for configuring the recognition algorithm
Enlarge
Screenshot of the wizard for configuring the recognition algorithm
 Playing Reversi against the computer (5.54 MByte video (https://vision.eng.shu.ac.uk/jan/reversi.avi))
Enlarge
Playing Reversi against the computer (5.54 MByte video (https://vision.eng.shu.ac.uk/jan/reversi.avi))

Possible Future Work

  • Port application to Ruby using HornetsEye and Qt4-Ruby
  • Port application to OpenMoko+Webcam
  • Support for libdc1394 version 2
  • Support for V4L version 2
  • Test with cheap IR-camera
  • Test with 90 fps camera
  • Gray code calibration
  • use histogram inversion instead of colour histograms
  • allow multi-touch (detect multiple pointers) by using local minima of boundary curve

You can help by donating some of your spare time and expertise ;)

See Also

External Links

Bookmark and Share

Personal tools