Difference between revisions of "Gps (API)"

From ComputerCraft Wiki
Jump to: navigation, search
m (<nowiki> goes *around* the `[`s. Also, greetings IRC from the middle of nowhere!)
m (Changed "axises" to "axes", changed formatting)
 
(8 intermediate revisions by 6 users not shown)
Line 1: Line 1:
 
The GPS API provides a method for turtles and computers to retrieve their own locations.
 
The GPS API provides a method for turtles and computers to retrieve their own locations.
  
It broadcasts a PING message over [[Rednet_(API)|rednet]] and wait for responses. In order for this system to work, there must be at least 4 computers used as gps ''hosts'' which will respond and allow [[Wikipedia:Trilateration|trilateration]]. Three of these hosts should be in a plane, and the fourth should be either above or below the other three. You can set up hosts using the [[Gps (program)|gps program]].
+
It broadcasts a PING message over [[Rednet_(API)|rednet]] and wait for responses. In order for this system to work, there must be at least 4 computers used as gps ''hosts'' which will respond and allow [[Wikipedia:Trilateration|trilateration]]. Three of these hosts should be in a plane, and the fourth should be either above or below the other three. The three in a plane should not be in a line with each other. You can set up hosts using the [[Gps (program)|gps program]].
 +
 
 +
Note:  When entering in the coordinates for the ''host'' you need to put in the x, y, and z coordinates of the '''computer''', not the modem, as all rednet distances are measured from the block the computer is in.
 +
 
 +
Also note that you may ''choose'' which axes x, y, or z refers to - so long as your systems have the same definition as any GPS servers that're in range, it works just the same. For example, you might build a GPS cluster according to [http://www.computercraft.info/forums2/index.php?/topic/3088-how-to-guide-gps-global-position-system/ this tutorial], using z to account for height, or you might use y to account for height in the way that Minecraft's debug screen displays.
  
Note:  When entering in the coordinates for the ''host'' you need to put in the x,y,z of the computer, not the modem, as all rednet distances are measured from the block the computer is in.
 
 
<!-- do not edit this without actually testing it yourself -->
 
<!-- do not edit this without actually testing it yourself -->
  
<table style="width: 100%; border: solid 1px black; margin: 2px; border-spacing: 0px;">
+
{{API table|Gps|image=Grid_disk.png|2=
<tr><td colspan="3" 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;
+
Gps (API)
+
</td></tr>
+
  
<tr><td style="width: 100px; background: #E0E0E0; padding: .4em; font-weight:bold;">Return</td><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|gps.locate(<nowiki>[</nowiki>{{type|number}} timeout [, {{Type|boolean}} debug]])|({{Type|number}} x, {{Type|number}} y, {{Type|number}} z) or {{Type|nil}}|Tries to retrieve the computer or turtles own location. On success, returns the location of the turtle’s modem. On failure (if no responses are received for <var>timeout</var> seconds, by default 2), returns {{Type|nil}}. If <var>debug</var> is <code>true</code>, debug messages are printed.|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">({{Type|int}} x, {{Type|int}} y, {{Type|int}} z), or [[nil]]</td>
+
}}
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">gps.locate(<nowiki>[</nowiki>{{Type|float}} timeout [, {{Type|boolean}} debug]])</td>
+
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Tries to retrieve the computer or turtles own location. On success, returns the location of the turtle’s modem. On failure (if no responses are received for <var>timeout</var> seconds, by default 2), returns [[nil]]. If <var>debug</var> is <code>true</code>, debug messages are printed.</td></tr></table>
+
  
 
== Example ==
 
== Example ==
 
   print("Man I am so lost right now!")
 
   print("Man I am so lost right now!")
 
   local x, y, z = gps.locate(5)
 
   local x, y, z = gps.locate(5)
   if x == nil then
+
   if not x then --If gps.locate didn't work, it won't return anything. So check to see if it did.
     print("Nope, still lost :(")
+
     print("Failed to get my location!")
 
   else
 
   else
     print("I am at ",x," ",y," ",z)
+
     print("I am at (" .. x .. ", " .. y .. ", " .. z .. ")") --This prints 'I am at (1, 2, 3)' or whatever your coordinates are
 
   end
 
   end
  
Line 34: Line 31:
 
   local displacement = position - home
 
   local displacement = position - home
 
    
 
    
   print("I am ", displacement.tostring(), " away from home!!!")
+
   print("I am ", tostring(displacement), " away from home!!!")
 
+
 
+
code>true
+
  
 
[[Category:APIs]]
 
[[Category:APIs]]

Latest revision as of 12:07, 14 August 2015

The GPS API provides a method for turtles and computers to retrieve their own locations.

It broadcasts a PING message over rednet and wait for responses. In order for this system to work, there must be at least 4 computers used as gps hosts which will respond and allow trilateration. Three of these hosts should be in a plane, and the fourth should be either above or below the other three. The three in a plane should not be in a line with each other. You can set up hosts using the gps program.

Note: When entering in the coordinates for the host you need to put in the x, y, and z coordinates of the computer, not the modem, as all rednet distances are measured from the block the computer is in.

Also note that you may choose which axes x, y, or z refers to - so long as your systems have the same definition as any GPS servers that're in range, it works just the same. For example, you might build a GPS cluster according to this tutorial, using z to account for height, or you might use y to account for height in the way that Minecraft's debug screen displays.


Grid disk.png  Gps (API)
Function Return values Description
gps.locate([number timeout [, boolean debug]]) (number x, number y, number z) or nil Tries to retrieve the computer or turtles own location. On success, returns the location of the turtle’s modem. On failure (if no responses are received for timeout seconds, by default 2), returns nil. If debug is true, debug messages are printed.

Example

 print("Man I am so lost right now!")
 local x, y, z = gps.locate(5)
 if not x then --If gps.locate didn't work, it won't return anything. So check to see if it did.
   print("Failed to get my location!")
 else
   print("I am at (" .. x .. ", " .. y .. ", " .. z .. ")") --This prints 'I am at (1, 2, 3)' or whatever your coordinates are
 end

Vector Example

GPS position and navigation can be handled more easily using a vector.

 local home = vector.new(45, 85, 20)
 local position = vector.new(gps.locate(5))
 local displacement = position - home
 
 print("I am ", tostring(displacement), " away from home!!!")