robotrack.php3 7.87 KB
Newer Older
1 2 3
<?php
#
# EMULAB-COPYRIGHT
4
# Copyright (c) 2000-2007 University of Utah and the Flux Group.
5 6 7 8 9 10 11
# All rights reserved.
#
chdir("..");
include("defs.php3");

PAGEHEADER("Real Time Robot Tracking Applet");

12 13 14 15
$this_user = CheckLoginOrDie();
$uid       = $this_user->uid();
$isadmin   = ISADMIN();

16 17 18 19 20 21 22 23 24
$optargs = OptionalPageArguments("building",    PAGEARG_STRING,
				 "floor",       PAGEARG_STRING,
				 "experiment",  PAGEARG_EXPERIMENT,
				 "camheight",   PAGEARG_INTEGER,
				 "camwidth",    PAGEARG_INTEGER,
				 "camfps",      PAGEARG_INTEGER,
				 "camera",      PAGEARG_INTEGER,
				 "withwebcams", PAGEARG_BOOLEAN);

25 26 27 28 29
#
# Optional pid,eid. Without a building/floor, show all the nodes for the
# experiment in all buildings/floors. Without pid,eid show all wireless
# nodes in the specified building/floor.
#
30 31 32
if (isset($experiment)) {
    if (!$experiment->AccessCheck($this_user, $TB_EXPT_READINFO)) {
	USERERROR("You do not have permission to view this experiment!", 1);
33
    }
34 35
    $pid = $experiment->pid()
    $eid = $experiment->eid()
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55
}
else {
    #
    # Else, we need to find whatever experiment is running. What if there
    # is more then one? Good question; I do not have a plan for that yet!
    #
    $query_result =
	DBQueryFatal("select pid,eid from experiments ".
		     "where locpiper_pid!=0 and locpiper_port!=0");
    if (mysql_num_rows($query_result)) {
	$row = mysql_fetch_array($query_result);
	$pid = $row["pid"];
	$eid = $row["eid"];
    }
    else {
	unset($pid);
	unset($eid);
    }
}

56
#
57
# Verify page arguments. Allow user to optionally specify building/floor.
58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
#
if (isset($building) && $building != "") {
    # Sanitize for the shell.
    if (!preg_match("/^[-\w]+$/", $building)) {
	PAGEARGERROR("Invalid building argument.");
    }
    # Optional floor argument. Sanitize for the shell.
    if (isset($floor) && !preg_match("/^[-\w]+$/", $floor)) {
	PAGEARGERROR("Invalid floor argument.");
    }
}
else {
    $building = "MEB-ROBOTS";
    $floor    = 4;
}
Leigh B. Stoller's avatar
Leigh B. Stoller committed
73 74 75 76 77 78 79 80 81 82 83 84
$ppm      = 1;

#
# Grab pixel_per_meters for above map.
#
$query_result =
    DBQueryFatal("select pixels_per_meter from floorimages ".
		 "where building='$building' and floor='$floor'");
if (mysql_num_rows($query_result)) {
    $row = mysql_fetch_array($query_result);
    $ppm = $row["pixels_per_meter"];
}
85 86 87
else {
    USERERROR("No such building/floor $building/$floor", 1);
}
88

89 90 91 92 93 94 95 96 97 98 99 100 101
#
# Some stuff to control the camera.
#
if (! isset($camheight) || !TBvalid_integer($camheight)) {
    $camheight = 180;
}
if (! isset($camwidth) || !TBvalid_integer($camwidth)) {
    $camwidth = 240;
}
if (! isset($camfps) || !TBvalid_integer($camfps)) {
    $camfps = 2;
}

102 103 104 105 106
#
# If adding in the webcams, get that stuff too.
#
$webcams = array();

107
if (isset($withwebcams) && $withwebcams) {
108 109 110 111 112 113
    if (isset($camera) && TBvalid_integer($camera)) {
	$query_result = DBQueryFatal("select * from webcams ".
				     "where id='$camera'");
    }
    else 
	$query_result = DBQueryFatal("select * from webcams");
114

115 116 117 118 119
    while ($row = mysql_fetch_array($query_result)) {
	$id      = $row["id"];
	$camurl  = "../webcamimg.php3?webcamid=${id}&applet=1&fromtracker=1";
	$webcams[] = $camurl;
    }
120 121
}

Leigh B. Stoller's avatar
Tweaks.  
Leigh B. Stoller committed
122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140
#
# Draw the legend and some explanatory text.
#
echo "<table cellspacing=5 cellpadding=5 border=0 class=\"stealth\">
      <tr>
       <td align=\"left\" valign=\"top\" class=\"stealth\">
         <table>
           <tr><th colspan=2>Legend</th></tr>
           <tr>
             <td><img src=\"../floormap/map_legend_node.gif\"></td>
             <td nowrap=1>Robot Actual Position</td>
           </tr>
           <tr>
             <td><img src=\"../floormap/map_legend_node_dst.gif\"></td>
             <td nowrap=1>Robot Destination Position</td>
           </tr>
         </table>
       </td>
       <td class=stealth>This applet allows you to view the robots
141 142
                         as they move around, as well as move the robots
                         with drag and drop. The table at the bottom
Leigh B. Stoller's avatar
Tweaks.  
Leigh B. Stoller committed
143
                         shows the current position (x, y, orientation),
Leigh B. Stoller's avatar
Leigh B. Stoller committed
144
                         the destination position,
Leigh B. Stoller's avatar
Tweaks.  
Leigh B. Stoller committed
145
                         and the battery level (percentage and voltage).
146
                         The shaded areas are <em>exclusion</em>
Leigh B. Stoller's avatar
Leigh B. Stoller committed
147
                         zones where robots are not allowed to go. You can
148 149
                         <b>right click</b> on a robot to bring up its
                         info page. See below for instructions on how to
150 151 152 153
                         use the <b>drag and drop</b> features. If you are on
                         a <b>high speed</b> connection, you can try the
                         <a href=${REQUEST_URI}&withwebcams=1>WithWebCams</a>
                         option.
Leigh B. Stoller's avatar
Tweaks.  
Leigh B. Stoller committed
154 155 156 157
        </td>
      </tr>
      </table><hr>\n";

158 159 160 161 162 163 164 165 166 167 168 169 170 171
#
# Create a tempfile to use as a unique prefix; it is not actually used but
# serves the same purpose (The script uses ${prefix}.jpg and ${prefix}.map .)
# 
$prefix = tempnam("/tmp", "floormap");

#
# Get the unique part to send back.
#
if (!preg_match("/^\/tmp\/([-\w]+)$/", $prefix, $matches)) {
    TBERROR("Bad tempnam: $prefix", 1);
}
$uniqueid = $matches[1];

172
$perl_args = "-o $prefix -t -z -n -x -v -y -f $floor $building";
173 174 175 176 177 178 179 180 181 182 183

$retval = SUEXEC($uid, "nobody", "webfloormap $perl_args",
		 SUEXEC_ACTION_IGNORE);

if ($retval) {
    SUEXECERROR(SUEXEC_ACTION_USERERROR);
    # Never returns.
    die("");
}

$auth    = $HTTP_COOKIE_VARS[$TBAUTHCOOKIE];
184
$pipeurl = "robopipe.php3?building=$building&floor=$floor";
185 186 187
$baseurl = "../floormap_aux.php3?prefix=$uniqueid";

# Temp for debugging.
Leigh B. Stoller's avatar
Leigh B. Stoller committed
188
if (isset($fake))
189 190 191 192
    $pipeurl .= "&fake=yes";
if (isset($pid) && isset($eid)) {
    $pipeurl .= "&pid=$pid&eid=$eid";
}
193
     
194
echo "<applet name='tracker' code='RoboTrack.class'
195
              archive='tracker.jar'
196
              width='1025' height='1150'
197 198
              alt='You need java to run this applet'>
            <param name='pipeurl' value='$pipeurl'>
199
            <param name='floorurl' value='$baseurl'>
200 201
            <param name='uid' value='$uid'>
            <param name='auth' value='$auth'>
Leigh B. Stoller's avatar
Leigh B. Stoller committed
202
            <param name='ppm' value='$ppm'>
203
            <param name='building' value='$building'>
204 205
            <param name='floor' value='$floor'>";
if (count($webcams)) {
206 207 208 209
    echo "<param name='WebCamHeight' value=$camheight>
          <param name='WebCamWidth' value=$camwidth>
          <param name='WebCamFPS' value=$camfps>\n";
    
210 211 212 213 214 215 216 217 218 219 220 221
    $camcount = count($webcams);
    $x = 400;
    $y = 460;
    
    echo "<param name='WebCamCount' value='$camcount'>";

    for ($i = 0; $i < $camcount; $i++) {
	$camurl = $webcams[$i];

	echo "<param name='WebCam${i}' value='$camurl'>
              <param name='WebCam${i}XY' value='$x,$y'>";

222
	$x += ($camwidth + 20);
223 224 225

	if ($x > 700) {
	    $x = 400;
226
	    $y = $y + ($camheight + 20);
227 228 229 230
	}
    }
}
echo "</applet>\n";
231

Leigh B. Stoller's avatar
Leigh B. Stoller committed
232
echo "<br>
233
     <blockquote><blockquote>
Leigh B. Stoller's avatar
Leigh B. Stoller committed
234 235
     <center>
     <h3>Using the Robot Tracker Applet</h3>
236
     </center>
Leigh B. Stoller's avatar
Leigh B. Stoller committed
237 238 239 240 241 242 243 244
     <ul>
     <li> Right Click over a robot or mote will pop up a browser window 
          showing information about the robot/mote.
     <li> Left click and drag over a (stationary) robot allows you to setup a
          move to a new position. Remember to edit the orientation in the
          table, if needed. Cancel by moving back to its original position. 
     <li> Left click over the background image brings up a menu to submit your 
          moves (start the robots on their way), or cancel the moves.
245 246
     <li> Only one move per robot at a time.
     <li> To change just the orientation (no drag), edit the destination
247 248 249
          orientation column in the table.
     <li> A robot destination must not overlap an obstacle (shaded area,
          blue border), and it must be fully within the field of view of at
250 251 252 253
          least one camera (orange boxes).
     <li> A robot destination must not overlap with another robot (its final
          destination). Because of the sensors on the robots, the closest a
          robot can come to anything else is 23cm.
254 255
     </ul>
     <blockquote><blockquote>\n";
256

257 258
PAGEFOOTER();
?>