Skip to content

Adding Instructions

Located in ExampleScripts \- Instructions

Overview

Here is how you can add instructions that will show up in a headset (wherever the user looks) and on the mirrored desktop view. This can be triggered using any event (such as a yield viztask.WaitTime ). This code is also under the "ExampleScripts" folder.  The default for skipping past the instruction is either with the left mouse click or controller trigger. 

Start and End Text

Use startExperimentText for instructions that show at the start of the experiment or startTrialText for text that shows at the start of each trial. 

yield sightlab.startTrial(startExperimentText="test", textContinueEvent="triggerPress")

End Experiment Text

yield sightlab.endTrial(endExperimentText="Done")

Example (note \n will create a new line, creating two here for an extra space)

yield sightlab.startTrial(
    startExperimentText="Look Around the Room nn Press Trigger when Ready"
)

Example: Note, have the startCondition set to 'None' in the GUI for the first trial if using startExperimentText, as the trigger will be used (can be changed to another condition in the code). Subsequent trial start and stop conditions can be set in GUI. 

#Add this code to the SightLabExperiment Function:

def sightLabExperiment():
 yield viztask.waitEvent(EXPERIMENT_START)

 for trial in range(sightlab.getTrialCount()):

  if sightlab.getTrialNumber() == 1:
   yield sightlab.startTrial(startExperimentText= 
   'Look Around the Room nn Press Trigger when Ready')
  elif sightlab.getTrialNumber() > 1:
   yield viztask.waitEvent(TRIAL_START)

  yield viztask.waitKeyDown(' ')
  yield sightlab.endTrial()

viztask.schedule(sightlab.runExperiment)
viztask.schedule(sightLabExperiment)
viz.callback(viz.getEventID('ResetPosition'), sightlab.resetViewPoint)

Basic Instructions

Basic Instructions that can be brought up anytime

yield sightlab.showInstructions('test', pauseTimer = True)
yield viztask.waitEvent('triggerPress')
yield sightlab.hideInstructions()

Image Based Instructions

quad = yield sightlab.showInstructions(image = 'sightlab_resources/media/skybox_room1.jpg')
Image Slides for Instructions

def sightLabExperiment():
 while True:
  #Press spacebar to cycle image instructions before first experiment starts
  sightlab.instructionsImageQuad.setScale([1,1.5,1])
  yield sightlab.showInstructions(image = 'sightlab_resources/sightlab_controls.jpg')
  yield viztask.waitKeyDown(' ')
  yield sightlab.showInstructions(image = 'sightlab_resources/sightlab_controls_oculus.jpg')
  sightlab.instructionsImageQuad.setScale([1.5,1,1])
  yield viztask.waitKeyDown(' ')
  yield sightlab.hideInstructions()

  while True:
   if not sightlab.getTrialNumber() == 1:
    yield viztask.waitKeyDown(' ')  
   yield sightlab.startTrial()
   yield viztask.waitKeyDown(' ')
   yield sightlab.endTrial()
viztask.schedule(sightlab.runExperiment)
viztask.schedule(sightLabExperiment)

Find also examples for adding multiple images or instruction text slides in the ExampleScripts

Another option for adding instructions at specific times and after certain conditions is to use a STIM file