-
Notifications
You must be signed in to change notification settings - Fork 283
Network Information
The X-Plane Connect network protocol is designed to extend the UDP data protocol provided by X-Plane. XPC's protocol is a strict superset of the X-Plane protocol.
Detailed information about the commands added by XPC are provided below.
The primary purpose of this page is to document the format of data as it travels over the network. For more information about the commands themselves, there is usually an obvious one-to-one mapping between these datagrams and commands described in the XPC Client Reference.
The following section describes commands using the following format:
Each command is presented as a table with 3 rows. The first row shows the byte number of the packet. The second row indicates the type of the data field. Finally, the third row gives a descriptor of the field. Interesting descriptors are described in more detail below the table. The first 4 bytes of each command are always ASCII characters, and their descriptors are character literals.
Symbol | Data Type |
---|---|
x | Padding byte |
C | ASCII Character |
B | Byte |
U16 | Unsigned 16-bit integer |
U32 | Unsigned 32-bit integer |
U64 | Unsigned 64-bit integer |
I16 | Signed 16-bit integer |
I32 | Signed 32-bit integer |
I64 | Signed 64-bit integer |
F | 32-bit float |
D | 64-bit float |
S | ASCII string |
ASCII strings are always preceded by a single byte indicating their length. Strings are not null terminated.
All multi-byte fields are transmitted in little-endian byte order.
CONF | CONN | CTRL | DATA | DREF | GETC | GETD | GETP | POSI | RESP | SIMU | TEXT | VIEW | WYPT
Summary: Sent in response to the CONN command on the new port.
Format:
0 | 1 | 2 | 3 | 4 | 5 |
---|---|---|---|---|---|
C | C | C | C | x | B |
C | O | N | F | - | id |
id
: The internal id of the client. Because this value is not exposed to the
client anywhere else, it is not actually useful. It is kept for legacy
compatibility.
Summary: Sets the port used to send data back to the sending client.
Format:
0 | 1 | 2 | 3 | 4 | 5 |
---|---|---|---|---|---|
C | C | C | C | x | U16 |
C | O | N | N | - | port |
port
: The port on which future data will be sent.
Summary: Sets the control surfaces of the specified aircraft.
Format:
0 | 1 | 2 | 3 | 4 | 5 | 9 | 13 | 17 | 21 | 22 | 26 | 27 |
---|---|---|---|---|---|---|---|---|---|---|---|---|
C | C | C | C | x | F | F | F | F | B | F | B | F |
C | T | R | L | - | e |
a |
r |
t |
g |
f |
ac |
sb |
e
: Elevator. Value should be in the range [-1, 1].
a
: Aileron. Value should be in the range [-1, 1].
r
: Rudder. Value should be in the range [-1, 1].
t
: Throttle. Value should be in the range [0, 1].
g
: Gear. Value should be 0, 1, or -1 (-1 toggles).
f
: Flaps. Value should be in the range [0, 1].
ac
: Aircraft number.
sb
: Speed brakes. Value should be in the range [-0.5, 1.5].
Summary: Sets data rows.
Format:
0 | 1 | 2 | 3 | 4 | 5 | 9 | ... | 37 | ... |
---|---|---|---|---|---|---|---|---|---|
C | C | C | C | x | U32 | F | F | F | - |
D | A | T | A | - | r1 |
v1^1 |
... | v1^8 |
... |
The DATA
command consists of any number of rows. No length byte is used; the
length is determined by dividing the packet length by 36 instead.
Summary: Sets the value of an X-Plane dataref.
Format:
0 | 1 | 2 | 3 | 4 | 5 | 6 | 6+n | 7+n | ... | 7+n+4(m-1) |
---|---|---|---|---|---|---|---|---|---|---|
C | C | C | C | x | B | S | B | F | F | F |
D | R | E | F | - | n |
dref |
m |
v^1 |
... | v^m |
n
: The length of dref
.
dref
: The name of the dataref being set.
m
: The number of values in the dataref.
v^1 to v^m
: The values of the dataref.
Summary: Sends a request to the plugin to get the control surface
information for a specific plane. The plugin will respond with a CTRL
packet.
Format:
0 | 1 | 2 | 3 | 4 | 5 |
---|---|---|---|---|---|
C | C | C | C | x | B |
G | E | T | C | - | n |
n
: The aircraft number to get information for.
Summary: Gets the value of one or more datarefs. This command's structure is difficult to represent in tabular form, but is fairly straightforward in practice. In short, the command has the standard header, followed by the number of datarefs being requested, followed by the dataref names.
Format:
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 7+n^1+1 | ... | Complicated | |
---|---|---|---|---|---|---|---|---|---|---|---|
C | C | C | C | x | B | B | S | B | S | B | S |
G | E | T | D | - | c |
n^1 |
dref^1 |
... | ... | n^c |
dref^c |
c
: The number of datarefs.
n^1 to n^c
: The length of each dref
.
dref^1 to dref^c
: The name of each dataref.
Summary: Sends a request to the plugin to get the position of a specific
plane. The plugin will respond with a POSI
packet.
Format:
0 | 1 | 2 | 3 | 4 | 5 |
---|---|---|---|---|---|
C | C | C | C | x | B |
G | E | T | P | - | n |
n
: The aircraft number to get information for.
Summary: Sets the position and orientation of an aircraft
Format:
0 | 1 | 2 | 3 | 4 | 5 | 6 | 10 | 14 | 18 | 22 | 26 | 30 |
---|---|---|---|---|---|---|---|---|---|---|---|---|
C | C | C | C | x | B | F | F | F | F | F | F | F |
P | O | S | I | - | ac |
lat |
lon |
el |
r |
p |
h |
g |
ac
: Aircraft number.
lat
: Latitude
lon
: Longitude
el
: Elevation (meters above sea level)
r
: Roll (degrees)
p
: Pitch (degrees)
r
: Roll (degrees)
h
: Heading (degrees)
g
: Gear (0 to retract, 1 to extend)
Summary: Returns value of one or more datarefs in response to the GETD command. This command's structure is difficult to represent in tabular form, but is fairly straightforward in practice. In short, the command has the standard header, followed by the number of datarefs that were requested requested, followed by the data itself
Format:
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | Complicated |
---|---|---|---|---|---|---|---|---|
C | C | C | C | x | B | B | F[] | ... |
G | E | T | D | - | c |
n^1 |
data^1 |
... |
c
: The number of datarefs.
n^1 to n^c
: The number of values in the result.
data^1 to data^c
: The result for each data ref. Values are always float, even
if the actual type of the dataref is int
or double
.
Summary: Enables or disables the physics simulation in X-Plane.
Format:
0 | 1 | 2 | 3 | 4 | 5 |
---|---|---|---|---|---|
C | C | C | C | x | B |
S | I | M | U | - | op |
op
: The operation to perform. 0 disables physics, 1 enables, and 2 toggles.
Summary: Sends a string to be drawn on the screen.
Format:
0 | 1 | 2 | 3 | 4 | 5 | 9 | 13 | 14 |
---|---|---|---|---|---|---|---|---|
C | C | C | C | x | I32 | I32 | B | S |
T | E | X | T | - | x |
y |
n |
str |
x
: The x coordinate where the string will be drawn.
y
: The y coordinate where the string will be drawn.
n
: The length of the string. Setting this to 0 will clear the current string
and disable drawing.
str
: The string itself.
Summary: Changes the camera mode in X-Plane
Format:
0 | 1 | 2 | 3 | 4 | 5 |
---|---|---|---|---|---|
C | C | C | C | x | I32 |
V | I | E | W | - | type |
type
: The command key associated with the desired view.
Summary: Manipulates a sequence of waypoints drawn in the world.
Format:
0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | ... | 6+4(3n-1) |
---|---|---|---|---|---|---|---|---|---|
C | C | C | C | x | B | B | F | F | F |
W | Y | P | T | - | op |
n |
v^1 |
... | v^3n |
op
: The operation to perform. 1 to add, 2 to remove, 3 to clear.
n
: The number of points.
v^1 to v^3n
: Values representing each point. Each triplet in this sequence is
treated as a (lat, lon, alt) point.