home *** CD-ROM | disk | FTP | other *** search
/ Chip: Shareware for Win 95 / Chip-Shareware-Win95.bin / ostatni / powerj / java.z / CheckboxMenuItem.java < prev    next >
Encoding:
Java Source  |  1996-05-03  |  2.2 KB  |  77 lines

  1. /*
  2.  * @(#)CheckboxMenuItem.java    1.8 95/09/08 Sami Shaio
  3.  *
  4.  * Copyright (c) 1995 Sun Microsystems, Inc. All Rights Reserved.
  5.  *
  6.  * Permission to use, copy, modify, and distribute this software
  7.  * and its documentation for NON-COMMERCIAL purposes and without
  8.  * fee is hereby granted provided that this copyright notice
  9.  * appears in all copies. Please refer to the file "copyright.html"
  10.  * for further important copyright and licensing information.
  11.  *
  12.  * SUN MAKES NO REPRESENTATIONS OR WARRANTIES ABOUT THE SUITABILITY OF
  13.  * THE SOFTWARE, EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
  14.  * TO THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A
  15.  * PARTICULAR PURPOSE, OR NON-INFRINGEMENT. SUN SHALL NOT BE LIABLE FOR
  16.  * ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING OR
  17.  * DISTRIBUTING THIS SOFTWARE OR ITS DERIVATIVES.
  18.  */
  19. package java.awt;
  20.  
  21. import java.awt.peer.CheckboxMenuItemPeer;
  22.  
  23. /**
  24.  * This class produces a checkbox that represents a choice in a menu.
  25.  *
  26.  * @version 1.8, 08 Sep 1995
  27.  * @author     Sami Shaio
  28.  */
  29. public class CheckboxMenuItem extends MenuItem {
  30.     boolean state = false;
  31.  
  32.     /**
  33.      * Creates the checkbox item with the specified label.
  34.      * @param label the button label
  35.      */
  36.     public CheckboxMenuItem(String label) {
  37.     super(label);
  38.     }
  39.  
  40.     /**
  41.      * Creates the peer of the checkbox item.  This peer allows us to
  42.      * change the look of the checkbox item without changing its 
  43.      * functionality.
  44.      */
  45.     public synchronized void addNotify() {
  46.     peer = Toolkit.getDefaultToolkit().createCheckboxMenuItem(this);
  47.     super.addNotify();
  48.     }
  49.  
  50.     /**
  51.      * Returns the state of this MenuItem. This method is only valid for a 
  52.      * Checkbox.
  53.      */
  54.     public boolean getState() {
  55.     return state;
  56.     }
  57.  
  58.     /**
  59.      * Sets the state of this MenuItem if it is a Checkbox.
  60.      * @param t the specified state of the checkbox
  61.      */
  62.     public void setState(boolean t) {
  63.     state = t;
  64.     CheckboxMenuItemPeer peer = (CheckboxMenuItemPeer)this.peer;
  65.     if (peer != null) {
  66.         peer.setState(t);
  67.     }
  68.     }
  69.  
  70.     /**
  71.      * Returns the parameter String of this button.
  72.      */
  73.     public String paramString() {
  74.     return super.paramString() + ",state=" + state;
  75.     }
  76. }
  77.