All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jdesktop.swingx.combobox.ListComboBoxModel Maven / Gradle / Ivy

There is a newer version: 1.7.2
Show newest version
/*
 * $Id: ListComboBoxModel.java 3935 2011-03-02 19:06:41Z kschaefe $
 *
 * Copyright 2004 Sun Microsystems, Inc., 4150 Network Circle,
 * Santa Clara, California 95054, U.S.A. All rights reserved.
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 */
package org.jdesktop.swingx.combobox;

import javax.swing.AbstractListModel;
import javax.swing.ComboBoxModel;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.List;

/**
 * A {@code ComboBoxModel} for {@code List}s.
 *
 * @param  the type of elements maintained by the list backing this model
 * @author jm158417
 * @author Karl George Schaefer
 */
public class ListComboBoxModel extends AbstractListModel implements ComboBoxModel, ActionListener {

    /**
     * A key used to notify the model that the backing {@code List} has changed.
     */
    public static final String UPDATE = "update";

    /**
     * A reference to the list backing this model.
     * 

* This model does not make a copy of the list, so any changes in * the list without synchronizing the model may have drastic effects. */ protected final List data; /** * The currently selected item. */ protected E selected; /** * Creates a {@code ListComboBoxModel} backed by the supplied {@code list}. * * @param list the list backing this model * @throws NullPointerException if {@code list} is {@code null} */ public ListComboBoxModel(List list) { this.data = list; if (list.size() > 0) { selected = list.get(0); } } /** * Set the selected item. The implementation of this method should notify * all registered {@code ListDataListener}s that the contents have changed. * * @param item the list object to select or {@code null} to clear the * selection * @throws ClassCastException if {@code item} is not of type {@code E} */ @Override @SuppressWarnings("unchecked") public void setSelectedItem(Object item) { if (selected != null && !selected.equals(item) || selected == null && item != null) { selected = (E) item; fireContentsChanged(this, -1, -1); } } /** * {@inheritDoc} */ @Override public E getSelectedItem() { return this.selected; } /** * {@inheritDoc} */ @Override public E getElementAt(int index) { return data.get(index); } /** * {@inheritDoc} */ @Override public int getSize() { return data.size(); } /** * {@inheritDoc} */ @Override public void actionPerformed(ActionEvent evt) { if (evt.getActionCommand().equals(UPDATE)) { this.fireContentsChanged(this, 0, getSize() - 1); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy