TableCellRenderers.java
上传用户:zhengdagz
上传日期:2014-03-06
资源大小:1956k
文件大小:4k
源码类别:

xml/soap/webservice

开发平台:

Java

  1. /*
  2.  * $Id: TableCellRenderers.java,v 1.6 2005/10/13 08:59:56 kleopatra Exp $
  3.  *
  4.  * Copyright 2004 Sun Microsystems, Inc., 4150 Network Circle,
  5.  * Santa Clara, California 95054, U.S.A. All rights reserved.
  6.  *
  7.  * This library is free software; you can redistribute it and/or
  8.  * modify it under the terms of the GNU Lesser General Public
  9.  * License as published by the Free Software Foundation; either
  10.  * version 2.1 of the License, or (at your option) any later version.
  11.  * 
  12.  * This library is distributed in the hope that it will be useful,
  13.  * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14.  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  15.  * Lesser General Public License for more details.
  16.  * 
  17.  * You should have received a copy of the GNU Lesser General Public
  18.  * License along with this library; if not, write to the Free Software
  19.  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
  20.  */
  21. package org.jdesktop.swingx.table;
  22. import java.util.Date;
  23. import java.util.HashMap;
  24. import javax.swing.Icon;
  25. import javax.swing.table.DefaultTableCellRenderer;
  26. import javax.swing.table.TableCellRenderer;
  27. import org.jdesktop.swingx.LinkModel;
  28. public class TableCellRenderers {
  29.     private static HashMap typeMap;
  30.     static {
  31.         // load the handler map with classes designed to handle the
  32.         // type-specific rendering
  33.         typeMap = new HashMap();
  34.         typeMap.put(Number.class,
  35.             "org.jdesktop.swingx.JXTable$NumberRenderer");
  36.         typeMap.put(Double.class,
  37.             "org.jdesktop.swingx.JXTable$DoubleRenderer");
  38.         typeMap.put(Float.class,
  39.             "org.jdesktop.swingx.JXTable$DoubleRenderer");
  40.         typeMap.put(Date.class,
  41.                     "org.jdesktop.swingx.JXTable$DateRenderer");
  42.         typeMap.put(Icon.class,
  43.                     "org.jdesktop.swingx.JXTable$IconRenderer");
  44.         typeMap.put(Boolean.class,
  45.             "org.jdesktop.swingx.JXTable$BooleanRenderer");
  46.         typeMap.put(LinkModel.class,
  47.                     "org.jdesktop.swingx.LinkRenderer");
  48.     }
  49.     private static String getRendererClassName(Class columnClass) {
  50.         String rendererClassName = (String) typeMap.get(columnClass);
  51.         return rendererClassName != null ? rendererClassName :
  52.             "javax.swing.table.DefaultTableCellRenderer";
  53.     }
  54.     /**
  55.      * @see #getNewDefaultRenderer
  56.      * @param columnClass Class of value being rendered
  57.      * @param rendererClassName String containing the class name of the renderer which
  58.      *        should be returned for the specified column class
  59.      */
  60.     public static void setDefaultRenderer(Class columnClass, String rendererClassName) {
  61.         typeMap.put(columnClass, rendererClassName);
  62.     }
  63.     /**
  64.      * Returns a new instance of the default renderer for the specified class.
  65.      * This differs from JTable:getDefaultRenderer() in that it returns a new
  66.      * instance each time so that the renderer may be set and customized for
  67.      * a particular column.
  68.      *
  69.      * @param columnClass Class of value being rendered
  70.      * @return TableCellRenderer instance which renders values of the specified type
  71.      */
  72.     public static TableCellRenderer getNewDefaultRenderer(Class columnClass) {
  73.         TableCellRenderer renderer = null;
  74.         String rendererClassName = getRendererClassName(columnClass);
  75.         try {
  76.             Class rendererClass = Class.forName(rendererClassName);
  77.             renderer = (TableCellRenderer) rendererClass.newInstance();
  78.         }
  79.         catch (Exception e) {
  80.             renderer = new DefaultTableCellRenderer();
  81.         }
  82.         return renderer;
  83.     }
  84.     TableCellRenderers() {
  85.     }
  86. }