From a JMRIusers thread:
?
*** General ***
JMRI SoundPro provides the basics for spatial sound. SoundPro and some third party audio libraries are the base for VSD and follow the specification of OpenAL. OpenAL is a 3D audio API appropriate for use with many types of audio applications.
The JMRI AudioExample.py script gives an impression of spatial sound (headphones or stereo speakers required).
If you like you can read about JMRI Audio objects on?
Some limitations: VSD doesn't support 3D audio. This would need a vertical speakers system. The sound wanders from left to right, from back to front and the reverse directions. The sound follows the loco, but it isn't as exact as an on-board-sound locomotive.
*** Requirements ***
It is good if JMRI 5.6 is installed. It is better to use a newer release of JMRI to benefit from the latest developments.
As already mentioned, headphones or stereo speakers are required. VSD works with one speaker. But spatial sound wouldn't appear. SoundPro and VSD include support for up-to 7.1 surround.
VSD works with LocoNet Transponding, or occupancy sensors, or without any tracking hardware.
I recommend to have a Layout Editor panel.
*** Set up ***
For a first try I recommend to test in JMRI Simulator mode, e.g. Digitrax LocoNet Simulator (no layout and connection needed).
If you like you can use the attached JMRI Profile. All is set up there to run the VSD demo.
Steps to enable the Profile:
1) Download and unzip the attached file.
2) Copy the Profile folder to your JMRI settings.
For Windows this is normally C:\your user name\JMRI.
3) Start PanelPro
4) Change your JMRI Preferences. Edit > Preferences > select "Config Profiles" > choose the VSD_Demo_spatialsound Profile > Activate it > click on Save and Restart
PanelPro restarts and executes the defined Start Up. Rearrange the windows as needed. Increase the throttle speed.
The current sound position is printed in the System Console. The unit of coordinates is in meter.
If it's not working please response to this topic. There a lots of variants running and setting up JMRI and I may have overseen a part.
To go back to your prior JMRI Profile change your JMRI Preferences again. Activate the prior Profile, save and restart.
Good luck!
*** Some background information ***
If you want to use your current LayoutEditor panel please make sure, that Tools > Check shows "No Results".
The panel must have at least one Track Segment. It is important (for a start block) to draw the Track Segment from left to right. VSD sees the forward direction of a loco from left to right (from west to east), clockwise. A Block must be assigned to each Track Segment.
For the VSD demo the VSDecoderPreferences option "useBlocks" must be unchecked. Note: this option was introduced in JMRI 5.5.3!
Here is an example for a VSDGeoData.xml file:
<?xml version="1.0" encoding="UTF-8"?> <vsdecoder-geodata xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <layout-scale>N</layout-scale> <check-time>2000</check-time> <models>My Layout</models> <models-origin>(346, 260, 0)</models-origin> </vsdecoder-geodata>
Additional documentation, like the attributs, is documented here:?
VSD uses JMRI rosters. VSD stores data in the Roster media, e.g. the path for the VSD files and the JMRI Profile name.
VSD uses blockvalues.xml to find a start Block. This is a new feature coming with JMRI 5.7.3.
To run a locomotive start PanelPro and load your LayoutEditor panel first. Then add a VSDecoder and start the engine. Now enter the DCC address in the Block Tables into a possible starting Block (if the DCC address matches "blockvalues.xml", this happens automatically - since JMRI 5.7.3), then increase the throttle speed.
Routes, Signals and Dispatcher are not tested.