/* * @(#)YcXTool.java 0.1 96/08/15 Jonathan Callahan * * * This software was developed by the Thermal Modeling and Analysis * Project(TMAP) of the National Oceanographic and Atmospheric * Administration's (NOAA) Pacific Marine Environmental Lab(PMEL), * hereafter referred to as NOAA/PMEL/TMAP. * * Access and use of this software shall impose the following * obligations and understandings on the user. The user is granted the * right, without any fee or cost, to use, copy, modify, alter, enhance * and distribute this software, and any derivative works thereof, and * its supporting documentation for any purpose whatsoever, provided * that this entire notice appears in all copies of the software, * derivative works and supporting documentation. Further, the user * agrees to credit NOAA/PMEL/TMAP in any publications that result from * the use of this software or in any product that includes this * software. The names TMAP, NOAA and/or PMEL, however, may not be used * in any advertising or publicity to endorse or promote any products * or commercial entity unless specific written permission is obtained * from NOAA/PMEL/TMAP. The user also understands that NOAA/PMEL/TMAP * is not obligated to provide the user with any support, consulting, * training or assistance of any kind with regard to the use, operation * and performance of this software nor to provide the user with any * updates, revisions, new versions or "bug fixes". * * THIS SOFTWARE IS PROVIDED BY NOAA/PMEL/TMAP "AS IS" AND ANY EXPRESS * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL NOAA/PMEL/TMAP BE LIABLE FOR ANY SPECIAL, * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF * CONTRACT, NEGLIGENCE OR OTHER TORTUOUS ACTION, ARISING OUT OF OR IN * CONNECTION WITH THE ACCESS, USE OR PERFORMANCE OF THIS SOFTWARE. * */ package dods.clients.importwizard.TMAP.map; import java.awt.Color; import java.awt.Graphics; import java.awt.Rectangle; //import dods.clients.importwizard.TMAP.map.XYTool; /** * A rectangular map tool defined by x, y, width and height. * * This tool draws a rubber-band box on the screen. * * @version 0.1, 15 Aug 1996 * @author Jonathan Callahan */ public class YcXTool extends XYTool { /** * Constructs and initializes an YcXTool with the specified parameters. * @param x the x coordinate * @param y the y coordinate * @param width the width of the YcXTool * @param height the height of the YcXTool */ public YcXTool(int x, int y, int width, int height, Color color) { super(x, y, width, height, color); } /** * Constructs an YcXTool and initializes it to the specified rectangle. * @param rect the rectangle of the YcXTool */ public YcXTool(Rectangle rect, Color color) { this(rect.x, rect.y, rect.width, rect.height, color); } /** * Draws an YcXTool. * * This method overrides the <code>abstract</code> method in * MapTool and allows us to instantiate an YcXTool. * @param g the graphics context for the drawing operation. */ public void draw(Graphics g) { int i=0; int [] x_array = {0, 0, 0, 0, 0, 0, 0}; int [] y_array = {0, 0, 0, 0, 0, 0, 0}; int poly_x, poly_y, poly_num=7; int poly_width=5, poly_height=3; g.setColor(color); g.drawLine(x+width/2, y, x+width/2, y+height); if ( drawHandles ) { handle[0].draw(g); handle[2].draw(g); handle[3].draw(g); handle[4].draw(g); handle[6].draw(g); handle[7].draw(g); } g.drawLine(x, y, x+width, y); poly_x = x+width/2; poly_y = y; x_array[0] =poly_x-poly_width; x_array[1] =poly_x; x_array[2] =poly_x+poly_width; x_array[3] =poly_x+poly_width; x_array[4] =poly_x; x_array[5] =poly_x-poly_width; x_array[6] =poly_x-poly_width; y_array[0] =poly_y-poly_height; y_array[1] =poly_y; y_array[2] =poly_y-poly_height; y_array[3] =poly_y+poly_height; y_array[4] =poly_y; y_array[5] =poly_y+poly_height; y_array[6] =poly_y-poly_height; g.fillPolygon(x_array, y_array, poly_num); g.drawLine(x, y+height/2, x+width, y+height/2); poly_y = y+height/2; y_array[0] =poly_y-poly_height; y_array[1] =poly_y; y_array[2] =poly_y-poly_height; y_array[3] =poly_y+poly_height; y_array[4] =poly_y; y_array[5] =poly_y+poly_height; y_array[6] =poly_y-poly_height; g.fillPolygon(x_array, y_array, poly_num); g.drawLine(x, y+height, x+width, y+height); poly_y = y+height; y_array[0] =poly_y-poly_height; y_array[1] =poly_y; y_array[2] =poly_y-poly_height; y_array[3] =poly_y+poly_height; y_array[4] =poly_y; y_array[5] =poly_y+poly_height; y_array[6] =poly_y-poly_height; g.fillPolygon(x_array, y_array, poly_num); } }