2001-04-22 11:05:39 +08:00
|
|
|
/* Copyright (C) 2000, 2001 Free Software Foundation
|
2000-08-03 20:09:41 +08:00
|
|
|
|
|
|
|
This file is part of libgcj.
|
|
|
|
|
|
|
|
This software is copyrighted work licensed under the terms of the
|
|
|
|
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
|
|
|
details. */
|
|
|
|
|
|
|
|
package java.awt;
|
2000-12-26 08:25:13 +08:00
|
|
|
import java.awt.event.*;
|
|
|
|
import java.awt.peer.CheckboxPeer;
|
2000-08-03 20:09:41 +08:00
|
|
|
|
2000-12-26 08:25:13 +08:00
|
|
|
/** This class implements a component which has an on/off state. Two
|
|
|
|
* or more Checkboxes can be grouped by a CheckboxGroup.
|
|
|
|
* @author Tom Tromey <tromey@redhat.com>
|
|
|
|
* @date December 25, 2000
|
|
|
|
*/
|
|
|
|
public class Checkbox extends Component implements ItemSelectable
|
2000-08-03 20:09:41 +08:00
|
|
|
{
|
2000-12-26 08:25:13 +08:00
|
|
|
/** Create a new checkbox.
|
|
|
|
* @param label The checkbox label. A null value is the same as "";
|
|
|
|
* this is the default.
|
|
|
|
* @param state The initial check state; defaults to false.
|
|
|
|
* @param group The CheckboxGroup. Defaults to null.
|
|
|
|
*/
|
|
|
|
public Checkbox ()
|
|
|
|
{
|
|
|
|
this (null, null, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Checkbox (String label)
|
|
|
|
{
|
|
|
|
this (label, null, false);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Checkbox (String label, boolean state)
|
|
|
|
{
|
|
|
|
this (label, null, state);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Checkbox (String label, boolean state, CheckboxGroup group)
|
|
|
|
{
|
|
|
|
this (label, group, state);
|
|
|
|
}
|
|
|
|
|
|
|
|
public Checkbox (String label, CheckboxGroup group, boolean state)
|
|
|
|
{
|
|
|
|
this.label = label;
|
|
|
|
this.group = group;
|
|
|
|
this.state = state;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Add a listener for item events.
|
|
|
|
* @param listener The listener to add.
|
|
|
|
*/
|
|
|
|
public synchronized void addItemListener (ItemListener listener)
|
|
|
|
{
|
|
|
|
listeners = AWTEventMulticaster.add (listeners, listener);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** This creates the component's peer. */
|
|
|
|
public void addNotify ()
|
|
|
|
{
|
|
|
|
if (peer == null)
|
|
|
|
peer = getToolkit ().createCheckbox (this);
|
2001-04-22 11:05:39 +08:00
|
|
|
super.addNotify ();
|
2000-12-26 08:25:13 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/** Returns the current CheckboxGroup associated with this
|
|
|
|
* Checkbox. */
|
|
|
|
public CheckboxGroup getCheckboxGroup ()
|
|
|
|
{
|
|
|
|
return group;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Returns the current label; might be null. */
|
|
|
|
public String getLabel ()
|
|
|
|
{
|
|
|
|
return label;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Returns this checkbox's label if this checkbox is selected. */
|
|
|
|
public Object[] getSelectedObjects ()
|
|
|
|
{
|
|
|
|
Object[] r;
|
|
|
|
if (state)
|
|
|
|
{
|
|
|
|
r = new Object[1];
|
|
|
|
r[0] = label;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
r = new Object[0];
|
|
|
|
return r;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Returns the current state of this checkbox. */
|
|
|
|
public boolean getState ()
|
|
|
|
{
|
|
|
|
return state;
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Generates a String representation of this Checkbox's state. */
|
|
|
|
protected String paramString ()
|
|
|
|
{
|
|
|
|
return ("Checkbox["
|
|
|
|
+ "state=" + state + ","
|
|
|
|
+ "label=" + label + ","
|
|
|
|
+ "group=" + group + "]");
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Process an event for this Checkbox.
|
|
|
|
* @param event The event the process.
|
|
|
|
*/
|
|
|
|
protected void processEvent (AWTEvent event)
|
|
|
|
{
|
|
|
|
if (event instanceof ItemEvent)
|
|
|
|
processItemEvent ((ItemEvent) event);
|
|
|
|
else
|
|
|
|
super.processEvent (event);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Process an item event for this Checkbox.
|
|
|
|
* @param event The ItemEvent to process
|
|
|
|
*/
|
|
|
|
protected void processItemEvent (ItemEvent event)
|
|
|
|
{
|
|
|
|
if (listeners != null)
|
|
|
|
listeners.itemStateChanged (event);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Remove an item listener.
|
|
|
|
* @param listener Item listener to remove.
|
|
|
|
*/
|
|
|
|
public synchronized void removeItemListener (ItemListener listener)
|
|
|
|
{
|
|
|
|
listeners = AWTEventMulticaster.remove (listeners, listener);
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Set this checkbox's group.
|
|
|
|
* @param group The new group. null means remove the Checkbox from
|
|
|
|
* its group.
|
|
|
|
*/
|
|
|
|
public void setCheckboxGroup (CheckboxGroup group)
|
|
|
|
{
|
|
|
|
this.group = group;
|
|
|
|
if (peer != null)
|
|
|
|
{
|
|
|
|
CheckboxPeer cp = (CheckboxPeer) peer;
|
|
|
|
cp.setCheckboxGroup (group);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Set the checkbox's label.
|
|
|
|
* @param label The new label
|
|
|
|
*/
|
|
|
|
public synchronized void setLabel (String label)
|
|
|
|
{
|
|
|
|
this.label = label;
|
|
|
|
if (peer != null)
|
|
|
|
{
|
|
|
|
CheckboxPeer cp = (CheckboxPeer) peer;
|
|
|
|
// FIXME: unclear what to do here; we err on the side of
|
|
|
|
// caution.
|
|
|
|
cp.setLabel (label == null ? "" : label);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/** Set the checkbox's state.
|
|
|
|
* @param state The new state.
|
|
|
|
*/
|
|
|
|
public void setState (boolean state)
|
|
|
|
{
|
|
|
|
this.state = state;
|
|
|
|
if (peer != null)
|
|
|
|
{
|
|
|
|
CheckboxPeer cp = (CheckboxPeer) peer;
|
|
|
|
cp.setState (state);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private ItemListener listeners;
|
|
|
|
|
|
|
|
String label;
|
|
|
|
CheckboxGroup group;
|
|
|
|
boolean state;
|
2000-08-03 20:09:41 +08:00
|
|
|
}
|