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

$uid = GETLOGIN();
LOGGEDINORDIE($uid);

PAGEHEADER("Real Time Robot Tracking Applet");

15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
#
# 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.
#
if (isset($pid) && $pid != "" && isset($eid) && $eid != "") {
    if (!TBvalid_pid($pid)) {
	PAGEARGERROR("Invalid project ID.");
    }
    if (!TBvalid_eid($eid)) {
	PAGEARGERROR("Invalid experiment ID.");
    }

    if (! TBValidExperiment($pid, $eid)) {
	USERERROR("The experiment $pid/$eid is not a valid experiment!", 1);
    }
    if (! TBExptAccessCheck($uid, $pid, $eid, $TB_EXPT_READINFO)) {
	USERERROR("You do not have permission to view experiment $pid/$eid!",
		  1);
    }
}
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);
    }
}

55
#
56
# Verify page arguments. Allow user to optionally specify building/floor.
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
#
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
72 73 74 75 76 77 78 79 80 81 82 83
$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"];
}
84 85 86
else {
    USERERROR("No such building/floor $building/$floor", 1);
}
87

88 89 90 91 92 93 94 95 96 97 98 99 100
#
# 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;
}

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

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

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

Leigh B. Stoller's avatar
Tweaks.  
Leigh B. Stoller committed
121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139
#
# 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
140 141
                         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
142
                         shows the current position (x, y, orientation),
Leigh B. Stoller's avatar
Leigh B. Stoller committed
143
                         the destination position,
Leigh B. Stoller's avatar
Tweaks.  
Leigh B. Stoller committed
144
                         and the battery level (percentage and voltage).
145
                         The shaded areas are <em>exclusion</em>
Leigh B. Stoller's avatar
Leigh B. Stoller committed
146
                         zones where robots are not allowed to go. You can
147 148
                         <b>right click</b> on a robot to bring up its
                         info page. See below for instructions on how to
149 150 151 152
                         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
153 154 155 156
        </td>
      </tr>
      </table><hr>\n";

157 158 159 160 161 162 163 164 165 166 167 168 169 170
#
# 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];

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

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

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

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

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

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

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

Leigh B. Stoller's avatar
Leigh B. Stoller committed
231
echo "<br>
232
     <blockquote><blockquote>
Leigh B. Stoller's avatar
Leigh B. Stoller committed
233 234
     <center>
     <h3>Using the Robot Tracker Applet</h3>
235
     </center>
Leigh B. Stoller's avatar
Leigh B. Stoller committed
236 237 238 239 240 241 242 243
     <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.
244 245
     <li> Only one move per robot at a time.
     <li> To change just the orientation (no drag), edit the destination
246 247 248
          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
249 250 251 252
          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.
253 254
     </ul>
     <blockquote><blockquote>\n";
255

256 257
PAGEFOOTER();
?>