source: josm/trunk/src/org/openstreetmap/josm/gui/OsmPrimitivRenderer.java@ 9621

Last change on this file since 9621 was 9078, checked in by Don-vip, 8 years ago

sonar - Immutable Field

  • Property svn:eol-style set to native
File size: 4.6 KB
Line 
1// License: GPL. For details, see LICENSE file.
2package org.openstreetmap.josm.gui;
3
4import java.awt.Component;
5import java.awt.Rectangle;
6
7import javax.swing.DefaultListCellRenderer;
8import javax.swing.ImageIcon;
9import javax.swing.JLabel;
10import javax.swing.JList;
11import javax.swing.JTable;
12import javax.swing.ListCellRenderer;
13import javax.swing.table.DefaultTableCellRenderer;
14import javax.swing.table.TableCellRenderer;
15
16import org.openstreetmap.josm.Main;
17import org.openstreetmap.josm.data.osm.OsmPrimitive;
18import org.openstreetmap.josm.data.osm.history.HistoryOsmPrimitive;
19import org.openstreetmap.josm.tools.ImageProvider;
20
21/**
22 * Renderer that renders the objects from an OsmPrimitive as data.
23 *
24 * Can be used in lists and tables.
25 *
26 * @author imi
27 * @author Frederik Ramm
28 */
29public class OsmPrimitivRenderer implements ListCellRenderer<OsmPrimitive>, TableCellRenderer {
30 private final DefaultNameFormatter formatter = DefaultNameFormatter.getInstance();
31
32 /**
33 * Default list cell renderer - delegate for ListCellRenderer operation
34 */
35 private final DefaultListCellRenderer defaultListCellRenderer = new DefaultListCellRenderer();
36
37 /**
38 * Default table cell renderer - delegate for TableCellRenderer operation
39 */
40 private final DefaultTableCellRenderer defaultTableCellRenderer = new DefaultTableCellRenderer();
41
42 /**
43 * Adapter method supporting the ListCellRenderer interface.
44 */
45 @Override
46 public Component getListCellRendererComponent(JList<? extends OsmPrimitive> list, OsmPrimitive value, int index,
47 boolean isSelected, boolean cellHasFocus) {
48 Component def = defaultListCellRenderer.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
49 return renderer(def, value);
50 }
51
52 /**
53 * Adapter method supporting the TableCellRenderer interface.
54 */
55 @Override
56 public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) {
57 Component def = defaultTableCellRenderer.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);
58 if (value instanceof OsmPrimitive)
59 return renderer(def, (OsmPrimitive) value);
60 else if (value instanceof HistoryOsmPrimitive)
61 return renderer(def, (HistoryOsmPrimitive) value);
62 else
63 return def;
64 }
65
66 /**
67 * Internal method that stuffs information into the rendering component
68 * provided that it's a kind of JLabel.
69 * @param def the rendering component
70 * @param value the OsmPrimitive to render
71 * @return the modified rendering component
72 */
73 private Component renderer(Component def, OsmPrimitive value) {
74 if (value != null && def instanceof JLabel) {
75 ((JLabel) def).setText(getComponentText(value));
76 ImageIcon icon = ImageProvider.getPadded(value,
77 // Height of component no yet known, assume the default 16px.
78 new Rectangle(16, 16));
79 if (icon != null) {
80 ((JLabel) def).setIcon(icon);
81 } else {
82 Main.warn("Null icon for "+value.getDisplayType());
83 }
84 ((JLabel) def).setToolTipText(getComponentToolTipText(value));
85 }
86 return def;
87 }
88
89 /**
90 * Internal method that stuffs information into the rendering component
91 * provided that it's a kind of JLabel.
92 * @param def the rendering component
93 * @param value the HistoryOsmPrimitive to render
94 * @return the modified rendering component
95 */
96 private Component renderer(Component def, HistoryOsmPrimitive value) {
97 if (value != null && def instanceof JLabel) {
98 ((JLabel) def).setText(value.getDisplayName(DefaultNameFormatter.getInstance()));
99 ((JLabel) def).setIcon(ImageProvider.get(value.getType()));
100 ((JLabel) def).setToolTipText(formatter.buildDefaultToolTip(value));
101 }
102 return def;
103 }
104
105 /**
106 * Returns the text representing an OSM primitive in a component.
107 * Can be overridden to customize the text
108 * @param value OSM primitive
109 * @return text representing the OSM primitive
110 */
111 protected String getComponentText(OsmPrimitive value) {
112 return value.getDisplayName(DefaultNameFormatter.getInstance());
113 }
114
115 /**
116 * Returns the text representing an OSM primitive in a tooltip.
117 * Can be overridden to customize the ToolTipText
118 * @param value OSM primitive
119 * @return text representing the OSM primitive
120 */
121 protected String getComponentToolTipText(OsmPrimitive value) {
122 return formatter.buildDefaultToolTip(value);
123 }
124}
Note: See TracBrowser for help on using the repository browser.