Difference between revisions of "Peripheral (API)"

From ComputerCraft Wiki
Jump to: navigation, search
m (Methods fix.)
m (Merged in Advanced Monitor methods.)
Line 1: Line 1:
The peripheral API is for interacting with external [http://en.wikipedia.org/wiki/Peripheral peripherals], such as the disk drive and monitor.<br />
+
The peripheral API is for interacting with external [http://en.wikipedia.org/wiki/Peripheral peripherals], such as the [[Disk Drive]], the [[Advanced Monitor]] and [[Monitor]].<br />
 
[[Console|Consoles]] and [[Turtle|Turtles]] are also considered peripherals and you can interface two adjacent computers, although in a more limited fashion compared to [[Rednet (API)|rednet]]. Both Computers and Turtles provide the same methods: ''turnOn'', ''shutdown'', ''reboot'', ''getID''.
 
[[Console|Consoles]] and [[Turtle|Turtles]] are also considered peripherals and you can interface two adjacent computers, although in a more limited fashion compared to [[Rednet (API)|rednet]]. Both Computers and Turtles provide the same methods: ''turnOn'', ''shutdown'', ''reboot'', ''getID''.
  
Line 43: Line 43:
 
|}
 
|}
 
==Monitor==
 
==Monitor==
List of methods:
 
 
 
'''''monitor'' stands for the variable you wrapped the monitor to.'''
 
'''''monitor'' stands for the variable you wrapped the monitor to.'''
 
''Example:'' monitor = peripheral.wrap( "top" )
 
''Example:'' monitor = peripheral.wrap( "top" )
 +
 +
Methods in ''italic'' are available on [[Advanced Monitor|Advanced Monitors]] only.
  
 
{| class="wikitable"
 
{| class="wikitable"
Line 52: Line 52:
 
!style="background:#EEE" width="*"|Description
 
!style="background:#EEE" width="*"|Description
 
|-
 
|-
|[[term.write|''monitor''.write]]()
+
|[[term.write|monitor.write]]()
 
|Write to the Monitor's screen.
 
|Write to the Monitor's screen.
 
|-
 
|-
|[[term.scroll|''monitor''.scroll]](n)
+
|[[term.scroll|monitor.scroll]](n)
 
|Scrolls the monitor screen.
 
|Scrolls the monitor screen.
 
|-
 
|-
|[[term.setCursorPos|''monitor''.setCursorPos]](x, y)
+
|[[term.setCursorPos|monitor.setCursorPos]](x, y)
 
|Sets the cursor position on the Monitor.
 
|Sets the cursor position on the Monitor.
 
|-
 
|-
|[[term.setCursorBlink|''monitor''.setCursorBlink]](b)
+
|[[term.setCursorBlink|monitor.setCursorBlink]](b)
 
|Enables or disables cursor blinking.
 
|Enables or disables cursor blinking.
 
|-
 
|-
|[[term.getCursorPos|''monitor''.getCursorPos]]()
+
|[[term.getCursorPos|monitor.getCursorPos]]()
 
|Returns two arguments containing the x and the y position of the cursor on the Monitor.
 
|Returns two arguments containing the x and the y position of the cursor on the Monitor.
 
|-
 
|-
|[[term.getSize|''monitor''.getSize]]()
+
|[[term.getSize|monitor.getSize]]()
 
|Returns two arguments containing the x and the y values stating the size of the Monitor.  
 
|Returns two arguments containing the x and the y values stating the size of the Monitor.  
 
|-
 
|-
|[[term.clear|''monitor''.clear]]()
+
|[[term.clear|monitor.clear]]()
 
|Clears the Monitor.
 
|Clears the Monitor.
 
|-
 
|-
|[[term.clearLine|''monitor''.clearLine]]()
+
|[[term.clearLine|monitor.clearLine]]()
 
|Clears the line the cursor is on.
 
|Clears the line the cursor is on.
 
|-
 
|-
|[[monitor.setTextScale|''monitor''.setTextScale]](scale)
+
|[[monitor.setTextScale|monitor.setTextScale]](scale)
 
|Sets the size of the text on the Monitor. Textscale can be between 0.5 and 5.0, with increments of 0.5
 
|Sets the size of the text on the Monitor. Textscale can be between 0.5 and 5.0, with increments of 0.5
 +
|-
 +
|''[[term.setTextColor|monitor.setTextColor]]([[colors (API)#colors|color]])''
 +
|Sets the text-color of the [[Advanced Monitor]]. Available only to [[Advanced Monitor|Advanced Monitors]]
 +
|-
 +
|''[[term.setBackgroundColor|monitor.setBackgroundColor]]([[colors (API)#colors|color]])''
 +
|Sets the background-color of the [[Advanced Monitor]]. Available only to [[Advanced Monitor|Advanced Monitors]]
 
|}
 
|}
  
 
==Printer==
 
==Printer==
List of methods:
 
 
 
'''''printer'' stands for the variable you wrapped the printer to.'''
 
'''''printer'' stands for the variable you wrapped the printer to.'''
 
''Example:'' printer = peripheral.wrap( "right" )
 
''Example:'' printer = peripheral.wrap( "right" )
Line 119: Line 123:
  
 
==Computers==
 
==Computers==
List of methods:
 
 
 
'''''computer'' stands for the variable you wrapped the computer to.'''
 
'''''computer'' stands for the variable you wrapped the computer to.'''
 
''Example:'' computer = peripheral.wrap( "top" )
 
''Example:'' computer = peripheral.wrap( "top" )
Line 128: Line 130:
 
!style="background:#EEE" width="*"|Description
 
!style="background:#EEE" width="*"|Description
 
|-
 
|-
|''computer''.turnOn()
+
|computer.turnOn()
 
|Turns on the Computer or Turtle.
 
|Turns on the Computer or Turtle.
 
|-
 
|-
|''computer''.shutdown()
+
|computer.shutdown()
 
|Shuts off the Computer or Turtle.
 
|Shuts off the Computer or Turtle.
 
|-
 
|-
|''computer''.reboot()
+
|computer.reboot()
 
|Reboots the Computer or Turtle.
 
|Reboots the Computer or Turtle.
 
|-
 
|-
|''computer''.getID()
+
|computer.getID()
 
|Gets the ID of the Computer or Turtle.
 
|Gets the ID of the Computer or Turtle.
 
|}
 
|}
 
[[Category:APIs]]
 
[[Category:APIs]]

Revision as of 15:04, 28 November 2012

The peripheral API is for interacting with external peripherals, such as the Disk Drive, the Advanced Monitor and Monitor.
Consoles and Turtles are also considered peripherals and you can interface two adjacent computers, although in a more limited fashion compared to rednet. Both Computers and Turtles provide the same methods: turnOn, shutdown, reboot, getID.

Methods

Method name Description
peripheral.isPresent(side) Returns true if a peripheral is present on side.
peripheral.getType(side) Returns the type or peripheral present on side, nothing returned if side is empty.
peripheral.getMethods(side) Returns a table containing all methods for peripheral on side.
peripheral.call(side, methodName, param1, param2, ...) Sends a function call to peripheral located on side. Return values match those of called method.

Note: methodName is a string.

peripheral.wrap(side) Returns a handle to the peripheral located on side. If assigned to a variable, it can be used to call all methods available from that peripheral, as if calling peripheral.call(), e.g.:

m = peripheral.wrap("left")
m.someMethod()
- is the same as -
peripheral.call("left","someMethod")

Events

Event name Description Parameters
peripheral Fired when peripheral is attached side
peripheral_detach Fired when peripheral is removed side

Monitor

monitor stands for the variable you wrapped the monitor to. Example: monitor = peripheral.wrap( "top" )

Methods in italic are available on Advanced Monitors only.

Method name Description
monitor.write() Write to the Monitor's screen.
monitor.scroll(n) Scrolls the monitor screen.
monitor.setCursorPos(x, y) Sets the cursor position on the Monitor.
monitor.setCursorBlink(b) Enables or disables cursor blinking.
monitor.getCursorPos() Returns two arguments containing the x and the y position of the cursor on the Monitor.
monitor.getSize() Returns two arguments containing the x and the y values stating the size of the Monitor.
monitor.clear() Clears the Monitor.
monitor.clearLine() Clears the line the cursor is on.
monitor.setTextScale(scale) Sets the size of the text on the Monitor. Textscale can be between 0.5 and 5.0, with increments of 0.5
monitor.setTextColor(color) Sets the text-color of the Advanced Monitor. Available only to Advanced Monitors
monitor.setBackgroundColor(color) Sets the background-color of the Advanced Monitor. Available only to Advanced Monitors

Printer

printer stands for the variable you wrapped the printer to. Example: printer = peripheral.wrap( "right" )

Method name Description
printer.newPage() Starts a new page. Returns true if page got started, false if not.
printer.endPage() Ends the page and prints the page to the output tray. Returns true if page was ended, false if not.
printer.write(text) Writes text to the paper, works the same way as term.write()
printer.setPageTitle(text) Sets the title of the page.
printer.getPaperLevel() Returns the amount of paper available in the paper tray.
printer.getInkLevel() Returns the amount of ink in the ink slot.
printer.getCursorPos() Returns the coordinates of the cursor on the paper, works the same way as term.getCursorPos()
printer.setCursorPos(x, y) Sets the cursor pos, works the same way as term.setCursorPos()
printer.getPageSize() Returns the size of the paper, works the same way as term.getSize()

Computers

computer stands for the variable you wrapped the computer to. Example: computer = peripheral.wrap( "top" )

Method name Description
computer.turnOn() Turns on the Computer or Turtle.
computer.shutdown() Shuts off the Computer or Turtle.
computer.reboot() Reboots the Computer or Turtle.
computer.getID() Gets the ID of the Computer or Turtle.