// $Id: UMLTreeCellRenderer.java 15887 2008-10-06 15:46:52Z tfmorris $ // Copyright (c) 1996-2008 The Regents of the University of California. All // Rights Reserved. Permission to use, copy, modify, and distribute this // software and its documentation without fee, and without a written // agreement is hereby granted, provided that the above copyright notice // and this paragraph appear in all copies. This software program and // documentation are copyrighted by The Regents of the University of // California. The software program and documentation are supplied "AS // IS", without any accompanying services from The Regents. The Regents // does not warrant that the operation of the program will be // uninterrupted or error-free. The end-user understands that the program // was developed for research purposes and is advised not to rely // exclusively on the program for any reason. IN NO EVENT SHALL THE // UNIVERSITY OF CALIFORNIA BE LIABLE TO ANY PARTY FOR DIRECT, INDIRECT, // SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST PROFITS, // ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF // THE UNIVERSITY OF CALIFORNIA HAS BEEN ADVISED OF THE POSSIBILITY OF // SUCH DAMAGE. THE UNIVERSITY OF CALIFORNIA SPECIFICALLY DISCLAIMS ANY // WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE // PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND THE UNIVERSITY OF // CALIFORNIA HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT, // UPDATES, ENHANCEMENTS, OR MODIFICATIONS. package org.argouml.uml.ui; import java.awt.Component; import javax.swing.Icon; import javax.swing.JLabel; import javax.swing.JTree; import javax.swing.tree.DefaultMutableTreeNode; import javax.swing.tree.DefaultTreeCellRenderer; import org.argouml.application.helpers.ResourceLoaderWrapper; import org.argouml.i18n.Translator; import org.argouml.model.Model; import org.argouml.uml.diagram.ui.UMLDiagram; /** * UMTreeCellRenderer determines how the entries in the Explorerpane * and ToDoList will be represented graphically.<p> * * In particular it makes decisions about the icons to use, * in order to display an Explorerpane artifact depending on the kind * of object to be displayed.<p> * * This class must be efficient as it is called many 1000's of times. */ public class UMLTreeCellRenderer extends DefaultTreeCellRenderer { // get localised strings once only private static String name = Translator.localize("label.name"); private static String typeName = Translator.localize("label.type"); //////////////////////////////////////////////////////////////// // TreeCellRenderer implementation /* * @see javax.swing.tree.TreeCellRenderer#getTreeCellRendererComponent( * javax.swing.JTree, java.lang.Object, boolean, boolean, boolean, int, * boolean) */ @Override public Component getTreeCellRendererComponent( JTree tree, Object value, boolean sel, boolean expanded, boolean leaf, int row, boolean hasFocusParam) { if (value instanceof DefaultMutableTreeNode) { value = ((DefaultMutableTreeNode) value).getUserObject(); } Component r = super.getTreeCellRendererComponent( tree, value, sel, expanded, leaf, row, hasFocusParam); if (value != null && r instanceof JLabel) { JLabel lab = (JLabel) r; // setting the icon Icon icon = ResourceLoaderWrapper.getInstance().lookupIcon(value); if (icon != null) { lab.setIcon(icon); } // setting the tooltip to type and name String type = null; if (Model.getFacade().isAModelElement(value)) { type = Model.getFacade().getUMLClassName(value); } else if (value instanceof UMLDiagram) { type = ((UMLDiagram) value).getLabelName(); } if (type != null) { StringBuffer buf = new StringBuffer(); buf.append("<html>"); buf.append(name); buf.append(' '); buf.append(lab.getText()); buf.append("<br>"); buf.append(typeName); buf.append(' '); buf.append(type); lab.setToolTipText(buf.toString()); } else { lab.setToolTipText(lab.getText()); } } return r; } }