No description
a395423f27
see also https://wiki.flightgear.org/Nasal_Optimisation#Emesary_real_time_executive Using a scheduler to manage the invocation of Nasal modules provides a more predictable and efficient way to replace update loops and also optimises property tree access to one access per property per frame by using a hash that contains the property values. There is a default global object created (emexec.ExecScheduler) that should be used in most circumstances. Each Nasal object simply has to have an update(notification) method. This will be called on a schedule and the notification will contain any requested property values. The exec will also adapt the rate to the frame rate; with a maximum of 50hz, but this will drop to as low as 4hz based on the frame rate to optimise workload. The modules will be called in the order in which they were added; so it is possible to have modules in the right sequence (i.e. an earlier module calculates values that are used by a later module) A simple example is below. The VSD_device has the update method ------ # list of prooperties to include in the notification hash var properties_to_monitor = { OrientationHeadingDeg : "orientation/heading-deg", OrientationPitchDeg : "orientation/pitch-deg", OrientationRollDeg : "orientation/roll-deg", GroundspeedKts : "velocities/groundspeed-kt", radar2_range : "instrumentation/radar/radar2-range", target_display : "sim/model/f15/instrumentation/radar-awg-9/hud/target-display", vc_kts : "instrumentation/airspeed-indicator/true-speed-kt", }; # create Canvas based device (that has an update method) VSD = VSD_Device.new(designation, textureImage, notification.Ident, root_node); # register with the exec; # - ident # - proprties to include in notification hash # - object (with an .update(notification) method # - rate (4 = 1/4) emexec.ExecModule.register("F15-VSD", properties_to_monitor, VSD, 4); |
||
---|---|---|
AI | ||
Aircraft | ||
Aircraft-aisim | ||
Aircraft-uiuc | ||
Airports | ||
Astro | ||
ATC | ||
Compositor | ||
Docs | ||
Effects | ||
Environment | ||
Fonts | ||
Geodata | ||
gui | ||
HLA | ||
Huds | ||
Input | ||
Lighting | ||
Materials | ||
Models | ||
MP | ||
Nasal | ||
Navaids | ||
Phi | ||
Protocol | ||
Shaders | ||
Sounds | ||
Textures | ||
Timezone | ||
Translations | ||
Video | ||
.gitignore | ||
AtlasPalette | ||
AUTHORS | ||
ChangeLog | ||
COPYING | ||
defaults.xml | ||
httpd-settings.xml | ||
joysticks.xml | ||
keyboard.xml | ||
location-presets.xml | ||
mice.xml | ||
NEWS | ||
options.xml | ||
README | ||
README-textures-ng | ||
runfgfs.bat | ||
Thanks | ||
version |
Welcome to the FlightGear Flight Simulator project. =================================================== The primary web page for this project is: http://www.flightgear.org For basic installation instructions see the "INSTALL" file. Before you can run FlightGear you will also need to download and install the "base" package which is a collection of textures, sounds, sample scenery, and other data files needed by the sim. For additional install help for specific platforms please browse the "docs-mini/" subdirectory. More complete documentation is available from our web page as a separate distribution. Please take a look at the "Thanks" file for a list of people who have contributed to this project. If you have contributed something but don't find your name in this file. Please send a polite reminder to http://www.flightgear.org/~curt For a summary of changes/additions by version see the "NEWS" file. This project is GPL'd. For complete details on our licensing please see the "COPYING" file. For information on available mailing lists, mailing list archives, and other available source code and documentation, please visit our web site. FlightGear is a product of the collaboration of large international group of volunteers. FlightGear is a work in progress. FlightGear comes with no warranty. We hope you enjoy FlightGear and/or find it of some value!