view java/src/uk/ac/qmul/eecs/ccmi/checkboxtree/CheckBoxTreeCellRenderer.java @ 8:ea7885bd9bff tip

fixed bug : render solid line as dotted/dashed when moving the stylus from dotted/dashed to solid
author ccmi-guest
date Thu, 03 Jul 2014 16:12:20 +0100
parents 9e67171477bc
children
line wrap: on
line source
/*  
 CCmI Editor - A Collaborative Cross-Modal Diagram Editing Tool
  
 Copyright (C) 2011  Queen Mary University of London (http://ccmi.eecs.qmul.ac.uk/)

 This program is free software: you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
 the Free Software Foundation, either version 3 of the License, or
 (at your option) any later version.

 This program 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 General Public License for more details.

 You should have received a copy of the GNU General Public License
 along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/
package uk.ac.qmul.eecs.ccmi.checkboxtree;

import java.awt.Component;

import javax.swing.BorderFactory;
import javax.swing.JCheckBox;
import javax.swing.JTree;
import javax.swing.tree.DefaultTreeCellRenderer;


/**
 * A tree cell renderer which renders {@code CheckBoxTreeNode} objects like a {@code JCheckBox}:
 * thick box (showing whether the node is selected or not) followed by a label (same label it would
 * appear with a default {@code DefaultTreeCellRenderer}.
 *
 */
@SuppressWarnings("serial")
public class CheckBoxTreeCellRenderer extends DefaultTreeCellRenderer {
	
	public CheckBoxTreeCellRenderer(){
		checkBox = new JCheckBox();
		checkBox.setBorder(BorderFactory.createLineBorder(this.getBorderSelectionColor()));
	}
	/**
	 * Returns the {@code Component} that the renderer uses to draw the value
	 * 
	 * @throws ClassCastException  if {@code value} is not an instance of {@code CheckoxTreeNode}
     * @see javax.swing.tree.TreeCellRenderer#getTreeCellRendererComponent(JTree, Object, boolean, boolean, boolean, int, boolean)
     * @return the {@code Component} that the renderer uses to draw the value
	 */
	@Override
	public Component getTreeCellRendererComponent(JTree tree,
            Object value,
            boolean selected,
            boolean expanded,
            boolean leaf,
            int row,
            boolean hasFocus){
		
		CheckBoxTreeNode treeNode = (CheckBoxTreeNode)value;  
		if(!treeNode.isSelectable())
			return super.getTreeCellRendererComponent(tree, value, selected, expanded, leaf, row, hasFocus);

		checkBox.setSelected(treeNode.isSelected());
		checkBox.setText(value.toString());
		if(selected){
			checkBox.setBackground(getBackgroundSelectionColor());
			checkBox.setBorderPainted(true);
		}else{
			checkBox.setBackground(getBackgroundNonSelectionColor());
			checkBox.setBorderPainted(false);
		}
		return checkBox;
	}

	private JCheckBox checkBox;
}