home *** CD-ROM | disk | FTP | other *** search
/ Programming Languages Suite / JBuilder8.iso / Solaris / resource / jre / demo / plugin / applets / ImageMap / HrefButtonArea.java < prev    next >
Encoding:
Java Source  |  2002-09-06  |  4.8 KB  |  157 lines

  1. /*
  2.  * Copyright (c) 2002 Sun Microsystems, Inc. All  Rights Reserved.
  3.  * 
  4.  * Redistribution and use in source and binary forms, with or without
  5.  * modification, are permitted provided that the following conditions
  6.  * are met:
  7.  * 
  8.  * -Redistributions of source code must retain the above copyright
  9.  *  notice, this list of conditions and the following disclaimer.
  10.  * 
  11.  * -Redistribution in binary form must reproduct the above copyright
  12.  *  notice, this list of conditions and the following disclaimer in
  13.  *  the documentation and/or other materials provided with the distribution.
  14.  * 
  15.  * Neither the name of Sun Microsystems, Inc. or the names of contributors
  16.  * may be used to endorse or promote products derived from this software
  17.  * without specific prior written permission.
  18.  * 
  19.  * This software is provided "AS IS," without a warranty of any kind. ALL
  20.  * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING
  21.  * ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE
  22.  * OR NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN AND ITS LICENSORS SHALL NOT
  23.  * BE LIABLE FOR ANY DAMAGES OR LIABILITIES SUFFERED BY LICENSEE AS A RESULT
  24.  * OF OR RELATING TO USE, MODIFICATION OR DISTRIBUTION OF THE SOFTWARE OR ITS
  25.  * DERIVATIVES. IN NO EVENT WILL SUN OR ITS LICENSORS BE LIABLE FOR ANY LOST
  26.  * REVENUE, PROFIT OR DATA, OR FOR DIRECT, INDIRECT, SPECIAL, CONSEQUENTIAL,
  27.  * INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY
  28.  * OF LIABILITY, ARISING OUT OF THE USE OF OR INABILITY TO USE SOFTWARE, EVEN
  29.  * IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
  30.  * 
  31.  * You acknowledge that Software is not designed, licensed or intended for
  32.  * use in the design, construction, operation or maintenance of any nuclear
  33.  * facility.
  34.  */
  35.  
  36. /*
  37.  * @(#)HrefButtonArea.java    1.11 02/06/13
  38.  */
  39.  
  40. import java.awt.Graphics;
  41. import java.awt.Image;
  42. import java.net.URL;
  43. import java.net.MalformedURLException;
  44.  
  45. /**
  46.  * An improved "Fetch a URL" ImageArea class.
  47.  * This class extends the basic ImageArea Class to fetch a URL when
  48.  * the user clicks in the area.  In addition, special custom highlights
  49.  * are used to make the area look and feel like a 3-D button.
  50.  *
  51.  * @author     Jim Graham
  52.  * @version     1.11, 06/13/02
  53.  */
  54. class HrefButtonArea extends ImageMapArea {
  55.     /** The URL to be fetched when the user clicks on this area. */
  56.     URL anchor;
  57.     /** The highlight image for when the button is "UP". */
  58.     Image upImage;
  59.     /** The highlight image for when the button is "DOWN". */
  60.     Image downImage;
  61.     /** This flag indicates if the "button" is currently pressed. */
  62.     boolean pressed = false;
  63.     /** The border size for the 3-D effect. */
  64.     int border = 5;
  65.  
  66.     /**
  67.      * The argument string is the URL to be fetched.
  68.      * This method also constructs the various highlight images needed
  69.      * to achieve the 3-D effect.
  70.      */
  71.     public void handleArg(String arg) {
  72.     try {
  73.         anchor = new URL(parent.getDocumentBase(), arg);
  74.     } catch (MalformedURLException e) {
  75.         anchor = null;
  76.     }
  77.     if (border * 2 > W || border * 2 > H) {
  78.         border = Math.min(W, H) / 2;
  79.     }
  80.     }
  81.  
  82.     public void makeImages() {
  83.     upImage = parent.getHighlight(X, Y, W, H,
  84.                       new ButtonFilter(false,
  85.                                parent.hlpercent,
  86.                                border, W, H));
  87.     downImage = parent.getHighlight(X, Y, W, H,
  88.                     new ButtonFilter(true,
  89.                              parent.hlpercent,
  90.                              border, W, H));
  91.     }
  92.  
  93.     public boolean imageUpdate(Image img, int infoflags,
  94.                    int x, int y, int width, int height) {
  95.     if (img == (pressed ? downImage : upImage)) {
  96.         return parent.imageUpdate(img, infoflags, x + X, y + Y,
  97.                       width, height);
  98.     } else {
  99.         return (img == downImage || img == upImage);
  100.     }
  101.     }
  102.  
  103.     /**
  104.      * The isTerminal method indicates whether events should propagate
  105.      * to the areas underlying this one.
  106.      */
  107.     public boolean isTerminal() {
  108.     return true;
  109.     }
  110.  
  111.     /**
  112.      * The status message area is updated to show the destination URL.
  113.      * The graphical highlight is achieved using the ButtonFilter.
  114.      */
  115.     public void highlight(Graphics g) {
  116.     if (entered) {
  117.         g.drawImage(pressed ? downImage : upImage, X, Y, this);
  118.     }
  119.     }
  120.  
  121.     public void enter() {
  122.     showStatus((anchor != null)
  123.            ? "Go To " + anchor.toExternalForm()
  124.            : null);
  125.     repaint();
  126.     }
  127.  
  128.     public void exit() {
  129.     showStatus(null);
  130.     repaint();
  131.     }
  132.  
  133.     /**
  134.      * Since the highlight changes when the button is pressed, we need
  135.      * to record the "pressed" state and induce a repaint.
  136.      */
  137.     public boolean press() {
  138.     pressed = true;
  139.     repaint();
  140.     return true;
  141.     }
  142.  
  143.     /**
  144.      * The new URL is fetched when the user releases the mouse button
  145.      * only if they are still in the area.
  146.      */
  147.     public boolean lift(int x, int y) {
  148.     pressed = false;
  149.     repaint();
  150.     if (inside(x, y) && anchor != null) {
  151.         showDocument(anchor);
  152.     }
  153.     return true;
  154.     }
  155. }
  156.  
  157.