Difference between revisions of "Printer (API)"

From ComputerCraft Wiki
Jump to: navigation, search
m (Added peripheral API message and fixed colspan issue)
m (Re-ordered functions)
 
(2 intermediate revisions by the same user not shown)
Line 1: Line 1:
 
{{PeripheralAPI}}
 
{{PeripheralAPI}}
  
{{NeedsWork|A short description and examples would be useful. - [[User:Oeed|Oeed]] 07:18, 26 March 2014 (GMT)}}
+
<br/>
 +
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.
  
The Printer API allows you to interact with printers.
+
All printer functions are to be used ''after'' [[peripheral.wrap|wrapping]] the printer.
  
<table style="width: 100%; border: solid 1px black; margin: 2px; border-spacing: 0px;">
+
{{API table|Printer|image=Grid disk.png|2=
<tr><td colspan="2" style="font-weight: bold; font-size: large; padding-bottom: .3em; border-bottom: solid #C9C9C9 1px; background: #D3FFC2; line-height:28px;">
+
[[File:Grid_disk.png|24px]]&nbsp;&nbsp;
+
Printer (API)
+
</td></tr>
+
  
<tr><td style="width: 350px; background: #E0E0E0; padding: .4em; font-weight:bold;">Method Name</td><td style="background: #E0E0E0; padding: .4em; font-weight:bold;">Description</td></tr>
+
{{API table/row
 +
|[[printer.newPage|''printer''.newPage]]()
 +
|{{type|boolean}} success
 +
|Starts a new page. Returns true if page got started, false if not.
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.getPaperLevel]]()</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Returns the amount of paper available in the paper tray.</td></tr>
+
|[[printer.endPage|''printer''.endPage]]()
 +
|{{type|boolean}} success
 +
|Ends the page and prints the page to the output tray. Returns true if page was ended, false if not.}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.newPage]]()</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Starts a new page. Returns true if page got started, false if not.</td></tr>
+
|[[printer.write|''printer''.write]]({{type|string}} text)
 +
|{{type|nil}}
 +
|Writes text to the paper, works the same way as [[term.write]]().
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.endPage]]()</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Ends the page and prints the page to the output tray. Returns true if page was ended, false if not.</td></tr>
+
|[[printer.setCursorPos|''printer''.setCursorPos]]({{type|number}} x, {{type|number}} y)
 +
|{{type|nil}}
 +
|Sets the cursor position on the paper, works the same way as [[term.setCursorPos]]().}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.write]]([[string]] text)</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Writes text to the paper, works the same way as [[term.write|term.write()]]</td></tr>
+
|[[printer.getCursorPos|''printer''.getCursorPos]]()
 +
|{{type|number}} x, {{type|number}} y
 +
|Returns the coordinates of the cursor on the paper, works the same way as [[term.getCursorPos]]().
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.setPageTitle]]([[string]] title)</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Sets the title of the page.</td></tr>
+
|[[printer.getPageSize|''printer''.getPageSize]]()
 +
|{{type|number}} width, {{type|number}} height
 +
|Returns the size of the paper, works the same way as [[term.getSize]]().}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.getInkLevel]]()</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Returns the amount of ink in the ink slot.</td></tr>
+
|[[printer.setPageTitle|''printer''.setPageTitle]]({{type|string}} title)
 +
|{{type|nil}}
 +
|Sets the title of the page.
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.getCursorPos]]()</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Returns the coordinates of the cursor on the paper, works the same way as [[term.getCursorPos|term.getCursorPos()]]</td></tr>
+
|[[printer.getPaperLevel|''printer''.getPaperLevel]]()
 +
|{{type|number}} paperAmount
 +
|Returns the amount of paper available in the paper tray.}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.setCursorPos]]({{type|number}} x, {{type|number}} y)</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Sets the cursor pos, works the same way as [[term.setCursorPos|term.setCursorPos()]]</td></tr>
+
|[[printer.getInkLevel|''printer''.getInkLevel]]()
 +
|{{type|number}} inkAmount
 +
|Returns the amount of ink in the ink slot.
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[printer.getPageSize]]()</td>
+
}}
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Returns the size of the paper, works the same way as [[term.getSize|term.getSize()]]</td></tr>
+
</table>
+
  
==Note==
+
__NOTOC__
All printer functions are to be used ''after'' wrapping the printer in a peripheral.
+
 
'''example''': printer = peripheral.wrap("left")
+
==Examples==
 +
 
 +
===Wrapping the printer===
 +
Before you try to print anything you first ''have'' to [[peripheral.wrap|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 "?".
  
 
[[Category:Peripheral APIs]]
 
[[Category:Peripheral APIs]]

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 "?".