This is an augmented reality application in the Unity game engine.
- Unity Pro 3.5.5 - the game engine. The Pro version is required, since it uses plugins.
- ALVAR 2.0.0 SDK - the augmented reality software library.
- OpenCV 2.4.0 - the third party library dependency of ALVAR.
This project is in two parts:
- ALVARBridge - this is the bridge between ALVAR's C++ functions and Unity C# scripts.
- AR-Unity - this is the Unity application, using the augmented reality.
This bridge creates an unmanaged DLL called ALVARBridge.dll. We need it, since ALVAR is in C++, and Unity doesn't support it, but supports C# scripts instead. This allows us to call C++ functions in C# scripts.
The following functions are used to detect markers in the image:
void alvar_init(int width, int height)
is used to initialize the detection of the markers.void alvar_process(int* imageData, double* transMatrix)
detect the markers, and modify the transformation matrix. This transformation matrix is then used in Unity to move any object on the markers.
The ALVARBridge.dll is directly exported in the Assets\Plugins directory of the Unity application.
Since this is inspired by DemoMarkerField, a demo application provided with the ALVAR library, the markers used are the same as this demo. You can found it in the ALVAR.pdf.
You need to calibrate your webcam. See the manual and ALVAR internal samples on how to calibrate your camera. The XML files for the calibration are in the Assets\Calibrations directory of the Unity application.
The current calibration file used is specific to my webcam.
Since our goal is to use the [Vuzix's Wrap 920AR] (http://www.vuzix.com/consumer/products_wrap920ar.html), some calibration files for these augmented reality eyewear are also present. These Wrap920_*.xml files come from the [Goblin XNA] (https://goblinxna.codeplex.com/) framework.
This is the Unity project.
The video stream of the webcam is projected on a plane, and an object ressembling a paper with markers is moving according to the detected markers. This object could be anything, as long as it is associated with the Marker.cs script.
There are four GameObjects in the scene:
- Cube: the object placed on the markers and moving according to their position and orientation.
- Directional light: used to light up the plane.
- Main Camera: the Unity camera, filming the Plane object.
- Plane: the webcam's stream is projected on it.
- ALVARBridge.cs: this is the bridge of the DLL in Unity.
- Background.cs: this script uses ALVAR functions to detect markers in the webcam's stream.
- Marker.cs: moves an object associated with this script, according to the markers.
This project is part of our final project at EPITA.