Skip to content

Model Viewer

Overview

The Model Viewer lets you place 3D models, Videos, Audio and Images into a folder and quickly view them. This can also be set up using the GUI

Create a new folder in the "collections" folder in the model viewer and add your models there, along with folders for "Videos", "Audio" and "Images".  You can simply drag and drop the model into a collection and now it is ready to be viewed in VR.  

Scene Controls

Move forward to next scene - v or "Y" button on LH controller

Move backward to last scene - c or "X" button on LH controller

Use highlighter tool (instructor) - RH or LH grip button or Right mouse button

Toggle Playback of Media (set to Auto play) - "1" key or LH thumbstick button down

Close Scene - "q" key or escape

Reset position - "r" key

Grab objects - Left mouse button or controller triggers

Can also use optional 3D menu for these actions

Toggle 'm' or press RH thumbstick to see menu

Movement

Desktop

WASD/Arrow keys: Movement.

X/Z: Vertical movement.

Q/E: Rotation.

/: Capture screen shot

HMD

Arc Teleport - RH thumbstick 

Magic Carpet - LH thumbstick while holding down RH B key to move forward/ backward/ side to side, 

LH thumbstick while holding down A key to move up/down

See this page for navigation and button mappings

controls 

To view the model collection, run ModelViewer.py, choose your hardware and choose the collection you want to view

Press either the 'v' and 'c' keys, the X and Y LH controller buttons (these can be configured to be different buttons or event in the mediaConfig.py file) , use the optional scene controller tool by grabbing the tool with your controller trigger or left mouse button and  clicking on the button that says "Next Model", or have the models change on a timer by setting Timer=True in the mediaConfig.py file and choosing how many seconds to have it model play after TimerValue = . 

Grabbing Objects and Adding as Objects of Interest

To grab objects  and add them as objects of interest you can add the word "_tag" after an object when setting up your scene in Inspector. Note: the older method of using a dictionary can still be used as well (see below). 

Additionally if you add the TV_Stand Object you can have a video play for each scene if you place it in a folder called "Videos" and title it the same name as the environment model (i.e. LectureHall.osgb model name and LectureHall.mp4 video)

The same goes for images in an "Images" folder, audio in an "Audio" folder

If you end the name of your environment and video with "_Large" it will play the video on a large, IMAX style screen (which can be stereo or monoscopic). 

#MediaViewer Settings
AUTO_PLAY_VIDEOS = True
LARGE_VIDEO_TYPE = 'Stereo'
STEREO_VIDEO_FORMAT = 'Left_Right'
THREE_SIXTY_VIDEO_TYPE = 'Stereo'
swapMediaKey = 'v' #Choose which key will advance the media, if not using a timer
backMediaKey = 'c'
mediaFolderPath = 'mediaPath'
collectionsPath = 'collections'
BIOPAC_ON = False
videoRecording = 0 #Choose whether to record a video, videos are saves in the recordings folder
Timer = False #Choose whether to advance the videos on a timer or a keypress. Set to true for the timer
TimerValue = 5  #Choose how many seconds to run the timer
cycleMedia = True
startExperimentKey = ' ' #choose which key will start the experiment
endExperimentKey = 'q' #choose which key will end the experiment
randomize = False
STARTING_POSITION = [0, 1.8, 0]

Controls for running in a Projection VR system with PPT wand:

Use the middle button to cycle between models/environments

Trigger to interact and pick up objects

Multi User

The Model Viewer will also work for Multiple Users (see MultiUserExampleScripts-Model and Media Viewer). Run the server, choose the collection, then run the Instructor script to have a user that can guide other clients through the session.

Older Method of Setting Objects for Grabbing

Older method for tagging objects using a dictionary, add this code to the mediaConfig file with the name of the environment and the name of the child objects

# Environment Settings
environments = ['']  # List of environment files.
grabbableObjects = ['']  # List of objects in the environment for grab or view interactions.
environ_dict = {
    'lab_empty.osgb': ['basketball1'],
    'ShowRoom_empty.osgb': ['basketball']
}  # Mapping of environments to their associated objects.