Difference between revisions of "Printer (API)"

From ComputerCraft Wiki
Jump to: navigation, search
m (Recreated table using {{API table}} tag, expanded description, added examples)
m (Re-ordered functions)
 
(One intermediate revision by the same user not shown)
Line 7: Line 7:
  
 
{{API table|Printer|image=Grid disk.png|2=
 
{{API table|Printer|image=Grid disk.png|2=
 
{{API table/row
 
|[[printer.getPaperLevel|''printer''.getPaperLevel]]()
 
|{{type|number}} paperAmount
 
|Returns the amount of paper available in the paper tray.
 
|odd}}
 
  
 
{{API table/row
 
{{API table/row
 
|[[printer.newPage|''printer''.newPage]]()
 
|[[printer.newPage|''printer''.newPage]]()
 
|{{type|boolean}} success
 
|{{type|boolean}} success
|Starts a new page. Returns true if page got started, false if not.}}
+
|Starts a new page. Returns true if page got started, false if not.
 +
|odd}}
  
 
{{API table/row
 
{{API table/row
 
|[[printer.endPage|''printer''.endPage]]()
 
|[[printer.endPage|''printer''.endPage]]()
 
|{{type|boolean}} success
 
|{{type|boolean}} success
|Ends the page and prints the page to the output tray. Returns true if page was ended, false if not.
+
|Ends the page and prints the page to the output tray. Returns true if page was ended, false if not.}}
|odd}}
+
  
 
{{API table/row
 
{{API table/row
 
|[[printer.write|''printer''.write]]({{type|string}} text)
 
|[[printer.write|''printer''.write]]({{type|string}} text)
 
|{{type|nil}}
 
|{{type|nil}}
|Writes text to the paper, works the same way as [[term.write]]().}}
+
|Writes text to the paper, works the same way as [[term.write]]().
 +
|odd}}
  
 
{{API table/row
 
{{API table/row
|[[printer.setPageTitle|''printer''.setPageTitle]]({{type|string}} title)
+
|[[printer.setCursorPos|''printer''.setCursorPos]]({{type|number}} x, {{type|number}} y)
 
|{{type|nil}}
 
|{{type|nil}}
|Sets the title of the page.
+
|Sets the cursor position on the paper, works the same way as [[term.setCursorPos]]().}}
|odd}}
+
 
+
{{API table/row
+
|[[printer.getInkLevel|''printer''.getInkLevel]]()
+
|{{type|number}} inkAmount
+
|Returns the amount of ink in the ink slot.}}
+
  
 
{{API table/row
 
{{API table/row
Line 48: Line 37:
  
 
{{API table/row
 
{{API table/row
|[[printer.setCursorPos|''printer''.setCursorPos]]({{type|number}} x, {{type|number}} y)
+
|[[printer.getPageSize|''printer''.getPageSize]]()
 +
|{{type|number}} width, {{type|number}} height
 +
|Returns the size of the paper, works the same way as [[term.getSize]]().}}
 +
 
 +
{{API table/row
 +
|[[printer.setPageTitle|''printer''.setPageTitle]]({{type|string}} title)
 
|{{type|nil}}
 
|{{type|nil}}
|Sets the cursor pos, works the same way as [[term.setCursorPos]]().}}
+
|Sets the title of the page.
 +
|odd}}
  
 
{{API table/row
 
{{API table/row
|[[printer.getPageSize|''printer''.getPageSize]]()
+
|[[printer.getPaperLevel|''printer''.getPaperLevel]]()
|{{type|number}} width, {{type|number}} height
+
|{{type|number}} paperAmount
|Returns the size of the paper, works the same way as [[term.getSize]]().
+
|Returns the amount of paper available in the paper tray.}}
 +
 
 +
{{API table/row
 +
|[[printer.getInkLevel|''printer''.getInkLevel]]()
 +
|{{type|number}} inkAmount
 +
|Returns the amount of ink in the ink slot.
 
|odd}}
 
|odd}}
  
Line 69: Line 69:
  
 
===Using the printer===
 
===Using the printer===
After wrapping it we can print use all functions from the Printer API:
+
After wrapping the printer we can use all functions from the Printer API:
 
  local printer = [[peripheral.wrap]]("left") -- Wrap the printer
 
  local printer = [[peripheral.wrap]]("left") -- Wrap the printer
 
  local ready = [[printer.newPage]]()
 
  local ready = [[printer.newPage]]()

Latest revision as of 19:09, 9 April 2014

This API requires the use of a wrapped peripheral!
This API does not behave like a regular API, to use it you must first wrap the peripheral and call the methods on the wrapped object. For more information see this page.


The Printer API allows you to interact with printers. Using it you can print on paper to create Printed Page. It also allows to get the current amount of paper and ink inside of the printer.

All printer functions are to be used after wrapping the printer.

Grid disk.png  Printer (API)
Function Return values Description
printer.newPage() boolean success Starts a new page. Returns true if page got started, false if not.
printer.endPage() boolean success Ends the page and prints the page to the output tray. Returns true if page was ended, false if not.
printer.write(string text) nil Writes text to the paper, works the same way as term.write().
printer.setCursorPos(number x, number y) nil Sets the cursor position on the paper, works the same way as term.setCursorPos().
printer.getCursorPos() number x, number y Returns the coordinates of the cursor on the paper, works the same way as term.getCursorPos().
printer.getPageSize() number width, number height Returns the size of the paper, works the same way as term.getSize().
printer.setPageTitle(string title) nil Sets the title of the page.
printer.getPaperLevel() number paperAmount Returns the amount of paper available in the paper tray.
printer.getInkLevel() number inkAmount Returns the amount of ink in the ink slot.


Examples

Wrapping the printer

Before you try to print anything you first have to wrap the printer. Lets say our printer is on the left side of the computer, we would wrap it like this:

local printer = peripheral.wrap("left")

Using the printer

After wrapping the printer we can use all functions from the Printer API:

local printer = peripheral.wrap("left") -- Wrap the printer
local ready = printer.newPage()

if ready then
  printer.write("This is on a paper")
  printer.setCursorPos(1, 3)
  printer.write("Setting cursor position")
  
  printer.setPageTitle("My page")
  printer.endPage()
else
  error("Could not create a page. Is there any paper and ink in the printer?")
end

Checking if there is ink and paper

Before you create a page you first have to check if there is paper to print on and if there is ink to print with in the printer. You can do that by using printer.getPaperLevel and printer.getInkLevel methods:

local printer = peripheral.wrap("left")

if printer.getPaperLevel() == 0 then -- If there is no paper in the printer
  error("There is no paper in the printer!")
end

if printer.getInkLevel() == 0 then -- If there is no ink in the printer
  error("There is no ink in the printer!")
end

-- There is paper and ink in the printer, we can now print a page

if printer.newPage() then
  printer.write("Tasks:")
  
  printer.setCursorPos(1, 3)
  printer.write("* Check melon farm")
  
  printer.setCursorPos(1, 4)
  printer.write("* Get more ender pearls")
  
  printer.setPageTitle("Tasks")
  printer.endPage()
else
  error("Page could not be created.")
end

Notes

  • Setting the title of the page is optional.
  • It is possible to print on already printed page. This way you can print one part of the page in one color and the other part in another color.
  • printer.write does not wrap words like print or write does. It also changes "\n" to "?".