1 package org.wcb.autohome.util;
2 /***
3 * Copyright (C) 1999 Walter Bogaardt
4 *
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
9 *
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
14 *
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the Free Software
17 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
18 *
19 * Project: Alice X10 Home Automation
20 */
21
22 import javax.swing.JLabel;
23 import javax.swing.JList;
24 import javax.swing.border.Border;
25 import javax.swing.BorderFactory;
26 import javax.swing.ListCellRenderer;
27 import java.awt.Color;
28 import java.awt.Component;
29 /***
30 * Filename: $Id: TriggerRenderer.java,v 1.3 2004/02/27 01:29:53 wbogaardt Exp $
31 *
32 * Abstract: This class handles rendering the various trigger items these being
33 * Time launched triggers, or Module activated triggers. This rendering
34 * occures mostly in the Macro Panels.
35 */
36 public class TriggerRenderer extends JLabel implements ListCellRenderer {
37
38 private Border redBorder = BorderFactory.createLineBorder(Color.green, 2),
39 emptyBorder = BorderFactory.createEmptyBorder(2, 2, 2, 2);
40
41 /***
42 * This sets up the customized cell render. Return a component that has been configured to display the specified
43 * value. That component's paint method is then called to "render" the cell. If it is necessary to compute the
44 * dimensions of a list because the list cells do not have a fixed size, this method is called to
45 * generate a component on which getPreferredSize can be invoked.
46 *
47 * @param list The JList we're painting.
48 * @param value The value returned by list.getModel().getElementAt(index).
49 * @param index The cells index.
50 * @param isSelected True if the specified cell was selected.
51 * @param cellHasFocus True if the specified cell has the focus.
52 * @return A component whose paint() method will render the specified value.
53 */
54 public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected,
55 boolean cellHasFocus) {
56 TriggerItem item = (TriggerItem) value;
57 setIcon(item.getIcon());
58 setText(item.toString());
59 if (isSelected)
60 {
61 setBorder(redBorder);
62 }
63 else
64 {
65 setBorder(emptyBorder);
66 }
67 return this;
68 }
69 }