Here you can find the source of selectByTyping(javax.swing.JList list, javax.swing.JTextField textfield)
Parameter | Description |
---|---|
list | the JList where the item should be selected |
textfield | the related filtertextfield that contains the user-input |
public static void selectByTyping(javax.swing.JList list, javax.swing.JTextField textfield)
//package com.java2s; /*//from w w w .j a v a2s . co m * Zettelkasten - nach Luhmann ** Copyright (C) 2001-2014 by Daniel L?decke (http://www.danielluedecke.de) * * Homepage: http://zettelkasten.danielluedecke.de * * * This program is free software; you can redistribute it and/or modify it under the terms of the * GNU General Public License as published by the Free Software Foundation; either version 3 of * the License, or (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License along with this program; * if not, see <http://www.gnu.org/licenses/>. * * * Dieses Programm ist freie Software. Sie k?nnen es unter den Bedingungen der GNU * General Public License, wie von der Free Software Foundation ver?ffentlicht, weitergeben * und/oder modifizieren, entweder gem?? Version 3 der Lizenz oder (wenn Sie m?chten) * jeder sp?teren Version. * * Die Ver?ffentlichung dieses Programms erfolgt in der Hoffnung, da? es Ihnen von Nutzen sein * wird, aber OHNE IRGENDEINE GARANTIE, sogar ohne die implizite Garantie der MARKTREIFE oder * der VERWENDBARKEIT F?R EINEN BESTIMMTEN ZWECK. Details finden Sie in der * GNU General Public License. * * Sie sollten ein Exemplar der GNU General Public License zusammen mit diesem Programm * erhalten haben. Falls nicht, siehe <http://www.gnu.org/licenses/>. */ import javax.swing.ListModel; public class Main { /** * This method selects the first entry in the JList {@code list} that start with the * text that is entered in the filter-textfield {@code textfield}. * * @param list the JList where the item should be selected * @param textfield the related filtertextfield that contains the user-input */ public static void selectByTyping(javax.swing.JList list, javax.swing.JTextField textfield) { String text = textfield.getText().toLowerCase(); ListModel lm = list.getModel(); for (int cnt = 0; cnt < lm.getSize(); cnt++) { String val = lm.getElementAt(cnt).toString(); if (val.toLowerCase().startsWith(text)) { list.setSelectedIndex(cnt); list.ensureIndexIsVisible(cnt); // and leave method return; } } } }