org.jdesktop.swingx.renderer.CheckBoxProvider Maven / Gradle / Ivy
/*
* Copyright 2006 Sun Microsystems, Inc., 4150 Network Circle,
* Santa Clara, California 95054, U.S.A. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
package org.jdesktop.swingx.renderer;
import javax.swing.AbstractButton;
import javax.swing.JLabel;
/**
* A component provider which uses a JCheckBox.
*
*
* This implementation respects a BooleanValue and a StringValue to configure
* the button's selected and text property. By default, the selected is mapped
* to a Boolean-type value and the text is empty.
*
*
* To allow mapping to different types, client code can supply a custom
* StringValue which also implements BooleanValue. F.i. to render a cell value
* of type TableColumnExt with the column's visibility mapped to the selected
* and the column's title to the text:
*
*
*
* BooleanValue bv = new BooleanValue(){
* public boolean getBoolean(Object value) {
* if (value instanceof TableColumnExt)
* return ((TableColumnExt) value).isVisible();
* return false;
* }
* };
* StringValue sv = new StringValue() {
* public String getString(Object value) {
* if (value instanceof TableColumnExt)
* return ((TableColumnExt) value).getTitle();
* return "";
* }
* };
* list.setCellRenderer(new DefaultListRenderer(
* new CheckBoxProvider(new MappedValue(sv, null, bv), JLabel.LEADING)));
*
*
*
* @see BooleanValue
* @see StringValue
* @see MappedValue
*
* @author Jeanette Winzenburg
*/
public class CheckBoxProvider extends ComponentProvider {
private boolean borderPainted;
/**
* Instantiates a CheckBoxProvider with default properties.
*
*/
public CheckBoxProvider() {
this(null);
}
/**
* Instantiates a CheckBoxProvider with the given StringValue and default alignment.
*
* @param stringValue the StringValue to use for formatting.
*/
public CheckBoxProvider(StringValue stringValue) {
this(stringValue, JLabel.CENTER);
}
/**
* Instantiates a CheckBoxProvider with the given StringValue and
* alignment.
*
* @param stringValue the StringValue to use for formatting.
* @param alignment the horizontalAlignment.
*/
public CheckBoxProvider(StringValue stringValue, int alignment) {
super(stringValue == null ? StringValues.EMPTY : stringValue, alignment);
setBorderPainted(true);
}
/**
* Returns the border painted flag.
* @return the borderpainted flag to use on the checkbox.
* @see #setBorderPainted(boolean)
*/
public boolean isBorderPainted() {
return borderPainted;
}
/**
* Sets the border painted flag. The underlying checkbox
* is configured with this value on every request.
*
* The default value is true.
*
* @param borderPainted the borderPainted property to configure
* the underlying checkbox with.
*
* @see #isBorderPainted()
*/
public void setBorderPainted(boolean borderPainted) {
this.borderPainted = borderPainted;
}
/**
* {@inheritDoc}
* Overridden to set the button's selected state and text.
*
* PENDING: set icon?
*
* @see #getValueAsBoolean(CellContext)
* @see #getValueAsString(CellContext)
*/
@Override
protected void format(CellContext context) {
rendererComponent.setSelected(getValueAsBoolean(context));
rendererComponent.setText(getValueAsString(context));
}
/**
* Returns a boolean representation of the content.
*
* This method messages the
* BooleanValue
to get the boolean rep. If none available,
* checks for Boolean type directly and returns its value. Returns
* false otherwise.
*
* PENDING: fallback to check for boolean is convenient .. could cleanup
* to use a default BooleanValue instead.
*
* @param context the cell context, must not be null.
* @return the boolean representation of the cell's content,
* or false if none if available.
*/
protected boolean getValueAsBoolean(CellContext context) {
if (stringValue instanceof BooleanValue) {
return ((BooleanValue) stringValue).getBoolean(context.getValue());
}
return Boolean.TRUE.equals(context.getValue());
}
/**
* {@inheritDoc}
*
* Here: set's the buttons horizontal alignment and borderpainted properties
* to this provider's properties.
*/
@Override
protected void configureState(CellContext context) {
rendererComponent.setBorderPainted(isBorderPainted());
rendererComponent.setHorizontalAlignment(getHorizontalAlignment());
}
/**
* {@inheritDoc}
* Here: returns a JCheckBox as rendering component.
*/
@Override
protected AbstractButton createRendererComponent() {
return new JRendererCheckBox();
}
}