forked from vranki/ExtPlane
-
Notifications
You must be signed in to change notification settings - Fork 0
bendyer/ExtPlane
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
*** ExtPlane *** X-Plane plugin that allows commanding X-Plane from external programs using an easy TCP protocol. * Features * - Multiple concurrent connections - Set and get datarefs - Dataref types supported: int, float, double, int[], float[] - Simulate key and button presses - Supports both X-Plane 9 and 10 - Free & Open Source under GPLv3 - Client classes for Qt included Known users: ExtPlane-Panel - a panel application @ https://github.com/vranki/ExtPlane-Panel GNU GPLv3, (c) Ville Ranki <[email protected]> Contributors: Bob Gates ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Downloading * Some binaries for various platforms are available in binaries/ directory. Just download a suitable binary and copy it to X-Plane/Resources/plugins/extplane.xpl. If a binary for your favorite platform is missing, please build it and send it to authors! ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Common build requirements * Copy X-Plane SDK to home directory, so that the headers can be found at ~/SDK/CHeaders/XPLM (or edit the .pro file). You'll need Qt development libraries installed. * To build on Mac & Linux * $ qmake $ make Mac notes: Warning! If you see any error or warning like : ld: in /opt/local/lib/libxslt.1.dylib, file was built for unsupported file format which is not the architecture being linked (i386) You need to rebuild libxslt with the +universal variant on MacPort otherwise the plugin cannot be loaded by X-Plane ! You should get the same for qt4-mac also. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Test session * Launch X-Plane in console and observe the output. You should see something like: TcpServer::TcpServer(QObject*, DataRefProvider*) Listening on port 51000 Open another console and run 'telnet localhost 51000' Wait until you see line 'EXTPLANE 1' Try typing the following commands: sub sim/cockpit/electrical/night_vision_on set sim/cockpit/electrical/night_vision_on 1 set sim/cockpit/electrical/night_vision_on 0 sub sim/flightmodel/position/local_y 100 set sim/flightmodel/position/local_y 3000 key 0 key 0 set sim/flightmodel/engine/ENGN_thro [1,0] set sim/flightmodel/engine/ENGN_thro [0,0] disconnect ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * Command reference * Datarefs: sub <dataref> [accuracy] - Subscribe to dataref, with optional accuracy. unsub <dataref> - Unsubscribe dataref. set <dataref> <value> - Set dataref to value. Dataref must be subscribed first. With accuracy you can decide how much the dataref's value can change before a update is sent. Set it to as large value as possible to maximize frame rate and minimize network traffic. List of datarefs can be found at: http://www.xsquawkbox.net/xpsdk/docs/DataRefs.txt Keys and buttons: key <key id> - Create a command key press. but <button id> - Press down an button. rel <button id> - Release button pressed using "but" command. List of key and button id's can be found at: http://www.xsquawkbox.net/xpsdk/mediawiki/XPLMUtilities Note that the key and button id's are numbers, not names. X-Plane does not provide a way to lookup keys or buttons by name. Other: disconnect - Disconnect the TCP socket. extplane-set <setting> <value> - Set ExtPlane setting Settings are: update_interval <value> - How often ExtPlane should update its data from X-Plane, in seconds. Use as high value as possible here for best performance. For example 0.16 would mean 60Hz, 0.33 = 30Hz, 0.1 = 10Hz etc.. Must be a positive float. Default is 0.33. * Plugin output * EXTPLANE <version> - Sent when connected. Version number is currently 1. u<type> <dataref> <value> - Update of dataref Array datarefs output data like this (a float array, size 4): ufa sim/flightmodel/position/q [0.84599,-0.00730657,0.00933933,0.533067] Set array datarefs the same way. You can give less values than the dataref holds. For example this sets full throttle to engines 1 & 2 set sim/flightmodel/engine/ENGN_thro [1,1] ExtPlane plugin outputs some log to stdout, so if you have problems with the plugin, start X-Plane in console and read the output. * Client library * See directory "client" for client code. Currently there is only client code for Qt. If you write client code for other environments (Python, Java..) please add them here. ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Comments and bug reports to [email protected] Official git repo at https://github.com/vranki/ExtPlane Contributions welcome!
About
Plugin for X-Plane flight simulator which allows reading and writing simulation properties
Resources
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published