-
Notifications
You must be signed in to change notification settings - Fork 44
New Readme
A plugin for X-Plane that allows commanding the simulation from external programs through an easy-to-use TCP protocol.
- Multiple concurrent connections
- Set and get datarefs
- Support for different dataref types: int, float, double, int[], float[], data
- 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 fully-featured interface for ExtPlane with tons of flight instruments and more
- https://github.com/vranki/ExtPlane-Panel
License:
- GNU GPLv3
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!
ExtPlane uses the Qt Framework for cross-platform compatibility. Before building you'll need to setup Qt 4.5 or greater to compile. You'll also need to check out the X-Plane SDK (http://www.xsquawkbox.net/xpsdk/mediawiki/Download) to the directory next to the ExtPlane directory. The X-Plane SDK can be either at ~/SDK or ../SDK or ../XPlaneSDK relative to the ExtPlane directory.
The requirements for ExtPlane are as follows:
- C++ Toolchain
- Qt Framework 4.5+
- X-Plane SDK 2.0+
# 1: Install required libraries and tools
sudo apt-get install git build-essential libqt4-dev
# 2: Download source code from GitHub
git clone https://github.com/dankrusi/XPlaneSDK.git
git clone https://github.com/vranki/ExtPlane.git
# 3: Build project
cd ExtPlane
qmake
make
# 1: Install required libraries and tools
# Download and install X-Code and Developer Tools from http://developer.apple.com
# Download and install Qt5 from http://qt-project.org/downloads
# 2: Download source code from GitHub
git clone https://github.com/dankrusi/XPlaneSDK.git
git clone https://github.com/vranki/ExtPlane.git
# 3: Build project
cd ExtPlane
qmake
make
# Note: If qmake is not on your command path, add the Qt bin directory to your path using
# export.
# 1: Install required libraries and tools
# Download and install Qt5 from http://qt-project.org/downloads
# Download and install Git from http://git-scm.com/downloads
# 2: Download source code from GitHub
git clone https://github.com/dankrusi/XPlaneSDK.git
git clone https://github.com/vranki/ExtPlane.git
# 3: Build project
cd ExtPlane
qmake
nmake
# Note: If you do not have a C++ compiler, you can install one of the following:
# MinGW version of Qt: http://qt-project.org/downloads
# Windows 7 SDK: http://www.microsoft.com/en-us/download/confirmation.aspx?id=8279
# Windows 8 SDK: http://msdn.microsoft.com/en-us/library/windows/desktop/hh852363.aspx
# Visual Studio Express: http://www.microsoft.com/visualstudio/eng/downloads#d-2012-express
Launch X-Plane in console and observe the output. You should see something like:
ExtPlane-Plugin: Listening on port 51000
. All console output from Ext-Plane
will start with ExtPlane-Plugin
.
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
- 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. For data datarefs, the accuracy represents the update interval in milliseconds.
List of datarefs can be found at: http://www.xsquawkbox.net/xpsdk/docs/DataRefs.txt
For example, to subscribe to the indicated heading with an accuracy of 10 degrees, send
sub sim/flightmodel/misc/h_ind 10.0
If you want to set a dataref which supports writing, you can send the following:
set sim/flightmodel/misc/h_ind 267.32
Array datarefs can be set the same way. You can give less values than the dataref holds. For example this sets full throttle for engines 1 & 2:
set sim/flightmodel/engine/ENGN_thro [1,1]
- 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.
- disconnect Disconnect the TCP socket.
- extplane-set {setting} {value} Set ExtPlane setting
Supported 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.
- EXTPLANE {version} Sent when connected. Version number is currently 1.
- u{type} {dataref} {value} Dataref has changed in value based on accuracy.
ui sim/aircraft/engine/acf_num_engines 2
uf sim/cockpit2/gauges/indicators/slip_deg -0.023
ud sim/flightmodel/misc/h_ind 267.32
Array datarefs output data like this (a float array, size 4):
ufa sim/flightmodel/position/q [0.84599,-0.00730657,0.00933933,0.533067]
uia sim/cockpit2/engine/indicators/N1_percent [99,97]
ExtPlane plugin outputs some log to stdout, so if you have problems with the
plugin, start X-Plane in console and look for any output starting with ExtPlane-Plugin
.
Client libraries can be found in the client
directory. Currently only a Qt c++ client
library is provided.
- Qt/C++
- A cross-platform Qt client library that allows easy integration of ExtPlane with Qt projects. This library also provides a simulation mode for quick and easy testing.
- https://github.com/vranki/ExtPlane/tree/master/client/extplane-client-qt
Original Author:
- Ville Ranki [email protected]
Contributors:
- Dan Krusi [email protected]
- Bob Gates
Contributions welcome!