我有一个显示SQL结果的动态JTable。我正在实现一个搜索功能,并选择包含所搜索值的所有单元格。 我正在使用JTable.changeSelection(row,col,true,false)。在JTable中,我实现了一个函数,该函数返回一个包含找到元素的行和列的对象的ArrayList。 只要有最大值,这个工作正常。 5搜索结果,在此之后它选择某种方式随机。这是我的代码:
private void searchTable() {
String pattern = JOptionPane.showInputDialog(scrollpane, "Pattern", "Find Text in Table", JOptionPane.QUESTION_MESSAGE);
if (pattern != null) {
Thread t = new Thread(new Runnable() {
public void run() {
busyCursor();
ArrayList<TableFindResult> tfr = dt.search(pattern);
SwingUtilities.invokeLater(new Runnable() {
public void run() {
tableView.setColumnSelectionAllowed(true);
tableView.setRowSelectionAllowed(true);
tableView.clearSelection();
int a = 1;
Iterator iter = tfr.iterator();
while (iter.hasNext()) {
TableFindResult t = (TableFindResult) iter.next();
tableView.changeSelection(t.getRow(), t.getCol(), true, false);
}
defaultCursor();
}
});
}
});
t.start();
} else {
tableView.clearSelection();
}
}
当结果少于5时,就是这样:
我已经调试验证,搜索功能,准备阵列正常工作。我的印象是JTable.changeSelection函数,它变得一团糟。但到目前为止我还没有找到解决方案。 我认为选择heses cell是个好主意,因为我的JdbcTable能够转换选定的行,所以这两个函数会协调一致。 有什么好主意吗? 非常感谢
答案 0 :(得分:1)
使用cellSelectionEnabled的JTable,选择所选行和所选列的交集。例如:如果选择单元格(r1,c1)和(r2,c2) - JTable选择(r1,c1),(r1,c2),(r2,c1)和(r2,c2)。
覆盖JTable中的isCellSelected
以获得您的预期行为。
在下面添加一个小例子:
package tableselection;
import java.awt.Point;
import java.awt.event.MouseEvent;
import java.util.ArrayList;
import java.util.List;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
public class TableSelection extends JFrame {
private static final long serialVersionUID = 1L;
String[] columnNames = { "First Name", "Last Name", "Sport", "# of Years", "Vegetarian" };
Object[][] data = { { "Kathy", "Smith", "Snowboarding", Integer.valueOf(5), Boolean.valueOf(false) },
{ "John", "Doe", "Rowing", Integer.valueOf(3), Boolean.valueOf(true) },
{ "Sue", "Black", "Knitting", Integer.valueOf(2), Boolean.valueOf(false) },
{ "Jane", "White", "Speed reading", Integer.valueOf(20), Boolean.valueOf(true) },
{ "Joe", "Brown", "Pool", Integer.valueOf(10), Boolean.valueOf(false) } };
public TableSelection() {
JPanel main = new JPanel();
JTable table = new JTable(data, columnNames) {
private static final long serialVersionUID = 1L;
List<Point> selected = new ArrayList<Point>();
@Override protected void processMouseEvent(MouseEvent e) {
if(e.getID() != MouseEvent.MOUSE_PRESSED)
return;
int row = ((JTable)e.getSource()).rowAtPoint(e.getPoint());
int col = ((JTable)e.getSource()).columnAtPoint(e.getPoint());
if(row >= 0 && col >= 0) {
Point p = new Point(row, col);
if(selected.contains(p))
selected.remove(p);
else
selected.add(p);
}
((JTable)e.getSource()).repaint();
}
@Override public boolean isCellSelected(int arg0, int arg1) {
return selected.contains(new Point(arg0, arg1));
}
};
JScrollPane pane = new JScrollPane(table);
main.add(pane);
this.add(main);
this.setSize(800, 600);
this.setVisible(true);
}
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
new TableSelection();
}
}