serial
Send and receive from a serial port
Arguments
port[symbol]
optional
Specifies the serial port to be used by the serial object. If alphabetic shortcuts (a-z) are used, specifies the first logical serial port in the computer, and - are used to specify additional ports.
portname[symbol]
optional
If actual portnames are used, the symbol is the name given by the Operating System to your port. The serial object can be used to create a list of available portnames and alphabetic shortcuts. If the port chosen is currently in use or unavailable when the serial object is instantiated, an error message will be displayed and the object will not function. If no port is specified, the default port is .
to the
rate[int]
optional
An optional argument may be used after the port name or alphabetic shortcut to specify the baud rate of the serial port (the default rate is 4800 baud). Any value is allowable (although not all ports can be set to all baud rates). Some common rates are 300, 600, 1200, 1800, 2400, 3600, 7200, 9600, 19200, 38400, 57600 and 115200.
data[int]
optional
After the baud rate, the next arguments specifies the number of data bits for the serial port (the default is 8 data bits). Other possible values are 5, 6 and 7.
stop[int]
optional
The next argument specifies the number of stop bits for the serial port. The default is 1. Other possible values are 1.5 (Windows only) and 2.
parity[int or symbol]
optional
The next argument specifies the parity for the serial port (the default is no parity, specified by
or ). Other possible values are (odd), and (even).Attributes
asyncread[int]: 0
By default (poll is enabled. When enabled ( = On), reading is performed regularly in the background, and a message (or polling) will cause the asynchronously read bytes to be output.
= Off), the object only reads from the serial port when a arrives, or if
autoopen[int]
Toggles automatically opening the serial port.
baud[int]
Specifies the baud rate of the serial port (the default rate is 4800 baud). Any value is allowable (although not all ports can be set to all baud rates). Some common rates are 300, 600, 1200, 1800, 2400, 3600, 7200, 9600, 19200, 38400, 57600 and 115200.
break_duration[int]: 1000
Specifies the duration of a break signal in microseconds (the default duration is 1ms, or 1000us). Some applications, such as DMX, require break durations in a particular range when marking frames.
bufsize[int]
Sets the input buffer size used by the serial object. The default buffer size is 2048.
chunk[int]
Sets the data chunk size (data list length) for output.
databits[int]
Sets the number of data bits (acceptable values are
, , , or ).
defer[int]: 1
Defer output of messages to the lower priority main thread. Most applicable when using Overdrive.
drain[int]
(Mac only) Toggles drain enable. When enabled, communication waits until all data has been transmitted to the terminal when writing. The default value is 0 (disabled).
dtr[int]: 2
Enables or disables the DTR (data terminal ready) function of the serial port used by the serial object.
Possible values:
0 = 'off'
(
Disable DTR
)
1 = 'on'
(
Enable DTR
)
2 = 'default'
(
Use the connection default (do not change)
)
parity[int]
Sets the parity for the port. Possible values are
(none), (odd) and (even).
poll[float]: 0.
postbreak_duration[int]: 0
Specify the duration of the post-break 'mark' (also known as Mark After Break, or MAB) in microseconds. The default MAB is 0us (that is, there is no MAB). Some applications, such as DMX, require the MAB when marking the beginning of frames.
rts[int]: 2
Enables or disables the RTS (Request To Send) line of the serial port used by the serial object. Note that this does not implement flow control.
Possible values:
0 = 'off'
(
Disable RTS
)
1 = 'on'
(
Enable RTS
)
2 = 'default'
(
Use the connection default (do not change)
)
serport[int]
Used by the object Inspector only. Users should use the
message.
stopbits[int]
Sets the number of stop bits used when communicating with the serial port. Possible values are
(1 stop bit) or (2 stop bits). On Windows, the values and can be used for 1.5 stop bits (not supported on macOS).
xonxoff[int]: 2
Enables Xon/Xoff serial flow control.
Possible values:
0 = 'off'
(
Disable Xon/Xoff flow control.
)
1 = 'on'
(
Enable Xon/Xoff flow control.
)
2 = 'default'
(
Use the connection default (do not change)
)
Common Box Attributes
annotation[symbol]
Sets the text that will be displayed in the Clue window when the user moves the mouse over the object.
background[int]: 0
Adds or removes the object from the patcher's background layer.
adds the object to the background layer, removes it. Objects in the background layer are shown behind all objects in the default foreground layer.
color[4 floats]
Sets the color for the object box outline.
fontface[int]
Sets the type style used by the object. The options are:
plain
bold
italic
bold italic
Possible values:
0 = 'regular'
1 = 'bold'
2 = 'italic'
3 = 'bold italic'
fontname[symbol]
Sets the object's font.
fontsize[float]
Sets the object's font size (in points).
Possible values:
'8'
'9'
'10'
'11'
'12'
'13'
'14'
'16'
'18'
'20'
'24'
'30'
'36'
'48'
'64'
'72'
hint[symbol]
Sets the text that will be displayed in as a pop-up hint when the user moves the mouse over the object in a locked patcher.
ignoreclick[int]: 0
Toggles whether an object ignores mouse clicks in a locked patcher.
jspainterfile[symbol]
JS Painter File
patching_rect[4 floats]: 0. 0. 100. 0.
Sets the position and size of the object in the patcher window.
position[2 floats]
write-only
Sets the object's x and y position in both patching and presentation modes (if the object belongs to its patcher's presentation), leaving its size unchanged.
presentation[int]: 0
Sets whether an object belongs to the patcher's presentation.
presentation_rect[4 floats]: 0. 0. 0. 0.
Sets the x and y position and width and height of the object in the patcher's presentation, leaving its patching position unchanged.
rect[4 floats]
write-only
Sets the x and y position and width and height of the object in both patching and presentation modes (if the object belongs to its patcher's presentation).
size[2 floats]
write-only
Sets the object's width and height in both patching and presentation modes (if the object belongs to its patcher's presentation), leaving its position unchanged.
textcolor[4 floats]
Sets the color for the object's text in RGBA format.
textjustification[int]
Sets the justification for the object's text.
Possible values:
0 = 'left'
1 = 'center'
2 = 'right'
varname[symbol]
Sets the patcher's scripting name, which can be used to address the object by name in pattr, scripting messages to thispatcher, and the js object.
Messages
bang
Sends each character received on the serial port since the last serial object's left outlet as an integer in the order that the characters were received. Before output data is sent, the message , followed by a number specifying the number of bytes received is sent out the right outlet of the serial object.
message out the
int
Sends the number out the serial port accessed by the serial object. Numbers outside the range 0-255 are wrapped to that range using a modulo operator. After the data is sent, the message , followed by a number specifying the number of bytes sent is sent out the right outlet of the serial object.
- input
[int]
float
Converted to
.- input
[float]
list
Sends each number in the list out the serial port, in order. Numbers outside the range 0-255 are wrapped to that range using a modulo operator. After the data is sent, the message serial object.
, followed by a number specifying the number of bytes sent is sent out the right outlet of the- input
[list]
break
Sends a break command to the serial port used by the serial object. After the break has completed, the message is sent out the object's right outlet.
close
Closes an open serial connection, permitting use of the serial port by other applications.
getport
Sends the name or shortcut of the currently open serial port out the serial object's right outlet, prepended by the word .
open
Opens a new serial connection.
port
The word port, followed by a symbol, specifies the serial port to be used by the object. If alphabetic shortcuts are used, a specifies the first logical serial port in the computer. b - z specify additional ports. If actual portnames are used, the symbol is the name given by the operating system to your port. See the
message for a way to list available portnames and alphabetic shortcuts. If the port chosen is currently in use or unavailable when the port message is sent, an error message will be displayed and the object will revert to its previously chosen port, or won't function if there was none.- port
[list]
print
Sends a list of available serial ports to the Max Console, along with their alphabetic shortcuts. The message
... is also sent from the object's right outlet, with a list of available ports.
refresh
Refreshes the list of known/available serial ports. See the
message for additional information.
reset
(Mac only) Resets the currently open serial port using the Basic Stamp initialization sequence.
Output
(serial output)
When a number or list is received in its inlet, serial sends the data out the specified serial port at the current baud rate.
int
When serial receives a message and characters have been received in the serial port, the received characters are sent as numbers in the order they were received.
list
When serial receives a message, characters have been received in the serial port, and chunking is enabled, the received characters are sent as a list in the order the characters were received. The length of the list is determined by the argument to the message (see the message listing for for more information).
Out right outlet: Reports error and status messages.
See Also
Name | Description |
---|---|
match | Watch for a message match, then output the message |
spell | Convert input to UTF-8 (Unicode) codes |
vdp | Control a videodisk player through a serial port |