annotate java/src/uk/ac/qmul/eecs/ccmi/checkboxtree/CheckBoxTreeCellRenderer.java @ 1:e3935c01cde2 tip

moved license of PdPersistenceManager to the beginning of the file
author Fiore Martin <f.martin@qmul.ac.uk>
date Tue, 08 Jul 2014 19:52:03 +0100
parents 78b7fc5391a2
children
rev   line source
f@0 1 /*
f@0 2 CCmI Editor - A Collaborative Cross-Modal Diagram Editing Tool
f@0 3
f@0 4 Copyright (C) 2011 Queen Mary University of London (http://ccmi.eecs.qmul.ac.uk/)
f@0 5
f@0 6 This program is free software: you can redistribute it and/or modify
f@0 7 it under the terms of the GNU General Public License as published by
f@0 8 the Free Software Foundation, either version 3 of the License, or
f@0 9 (at your option) any later version.
f@0 10
f@0 11 This program is distributed in the hope that it will be useful,
f@0 12 but WITHOUT ANY WARRANTY; without even the implied warranty of
f@0 13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
f@0 14 GNU General Public License for more details.
f@0 15
f@0 16 You should have received a copy of the GNU General Public License
f@0 17 along with this program. If not, see <http://www.gnu.org/licenses/>.
f@0 18 */
f@0 19 package uk.ac.qmul.eecs.ccmi.checkboxtree;
f@0 20
f@0 21 import java.awt.Component;
f@0 22
f@0 23 import javax.swing.BorderFactory;
f@0 24 import javax.swing.JCheckBox;
f@0 25 import javax.swing.JTree;
f@0 26 import javax.swing.tree.DefaultTreeCellRenderer;
f@0 27
f@0 28
f@0 29 /**
f@0 30 * A tree cell renderer which renders {@code CheckBoxTreeNode} objects like a {@code JCheckBox}:
f@0 31 * thick box (showing whether the node is selected or not) followed by a label (same label it would
f@0 32 * appear with a default {@code DefaultTreeCellRenderer}.
f@0 33 *
f@0 34 */
f@0 35 @SuppressWarnings("serial")
f@0 36 public class CheckBoxTreeCellRenderer extends DefaultTreeCellRenderer {
f@0 37
f@0 38 public CheckBoxTreeCellRenderer(){
f@0 39 checkBox = new JCheckBox();
f@0 40 checkBox.setBorder(BorderFactory.createLineBorder(this.getBorderSelectionColor()));
f@0 41 }
f@0 42 /**
f@0 43 * Returns the {@code Component} that the renderer uses to draw the value
f@0 44 *
f@0 45 * @throws ClassCastException if {@code value} is not an instance of {@code CheckoxTreeNode}
f@0 46 * @see javax.swing.tree.TreeCellRenderer#getTreeCellRendererComponent(JTree, Object, boolean, boolean, boolean, int, boolean)
f@0 47 * @return the {@code Component} that the renderer uses to draw the value
f@0 48 */
f@0 49 @Override
f@0 50 public Component getTreeCellRendererComponent(JTree tree,
f@0 51 Object value,
f@0 52 boolean selected,
f@0 53 boolean expanded,
f@0 54 boolean leaf,
f@0 55 int row,
f@0 56 boolean hasFocus){
f@0 57
f@0 58 CheckBoxTreeNode treeNode = (CheckBoxTreeNode)value;
f@0 59 if(!treeNode.isSelectable())
f@0 60 return super.getTreeCellRendererComponent(tree, value, selected, expanded, leaf, row, hasFocus);
f@0 61
f@0 62 checkBox.setSelected(treeNode.isSelected());
f@0 63 checkBox.setText(value.toString());
f@0 64 if(selected){
f@0 65 checkBox.setBackground(getBackgroundSelectionColor());
f@0 66 checkBox.setBorderPainted(true);
f@0 67 }else{
f@0 68 checkBox.setBackground(getBackgroundNonSelectionColor());
f@0 69 checkBox.setBorderPainted(false);
f@0 70 }
f@0 71 return checkBox;
f@0 72 }
f@0 73
f@0 74 private JCheckBox checkBox;
f@0 75 }