Как я могу скрыть (сделать невидимой) строку в JTable?
Вопрос
Есть ли способ сделать это?
Решение
А лучший проще всего было бы удалить соответствующий элемент из модели.
Другие советы
Здесь RowFilter<DefaultTableModel, Object>
класс, который вы можете использовать для фильтрации строк.DefaultTableModel можно заменить собственной моделью.Для фильтрации реализуйте метод
@Override
public boolean include(Entry entry) {
// All rows are included if no filter is set
if (filterText.isEmpty())
return true;
// If any of the column values contains the filter text,
// the row can be shown
for (int i = 0; i < entry.getValueCount(); i++) {
String value = entry.getStringValue(i);
if (value.toLowerCase().indexOf(filterText) != -1)
return true;
}
return false;
}
При доступе к строкам, например при прослушивании ListSelectionEvents, не забудьте преобразовать видимый индекс строки в полный индекс строки в вашей модели.Java также предоставляет функцию для этого:
public void valueChanged(ListSelectionEvent e) {
ListSelectionModel lsm = (ListSelectionModel) e.getSource();
int visibleRowIndex = ... // Get the index of the selected row
// Convert from the selection index based on the visible items to the
// internal index for all elements.
int internalRowIndex = tableTexts
.convertRowIndexToModel(visibleRowIndex);
...
}
Проверить Учебник Sun для JTables и посмотрите раздел «Сортировка и фильтрация».
Вы можете настроить списки массивов для каждого столбца, заполненные значениями, отфильтрованными по ним, и реализовать их в пользовательском средстве визуализации.Если значения всей строки ячейки не выполняются, средство рендеринга рекурсивно вызывает себя с помощью строки +1.
если строка ячеек соответствует критериям, она визуализируется, другой массив хранит уже обработанные номера строк, лучше всего это объяснить на примере, этот метод находится в клиентском рендерере, расширяет JLabel
public Component getTableCellRendererComponent(JTable table, Object color,
boolean isSelected, boolean hasFocus, int row, int column) {
Object value;
String s;
try {
if (row == 0) {
drawn[column].clear();
}// drawn is arraylist which stores cols rend
if (row > table.getModel().getDataVector.size()) {
return null;
}// if we go too far
if (drawn[column].contains(Integer.toString(row)) == true) {
// already rendered?
return getTableCellRendererComponent(table, color, isSelected,
hasFocus, (row + 1), column);
}// render row+1
for (int i = 0; i < filters.length; i++) {
value = table.getModel().getValueAt(row, i);
s = (i == 1) ? df.format(value) : value.toString();
if (filters[i].contains(s) != true) {
//try and put in next row, if succeeds when it reaches column 8 it adds row to
return getTableCellRendererComponent(table, color,
isSelected, hasFocus, (row + 1), column);
}
}
value = table.getModel().getValueAt(row, column);
setFont(getFont().deriveFont(Font.BOLD));
if ((isSelected == false)) {
if ((column == 1)) {
setForeground(Color.magenta);
}// just formatting
else {
setForeground(Color.black);
setBackground(Color.white);
}
} else {
setBackground(Color.blue);
setForeground(Color.white);
}
if ((column == 1))// col 1 is a date, other columns strings
{
setText((value == null) ? "" : df.format(value));
} else {
setText((value == null) ? "" : value.toString());
}
todayStr = df.format(new java.util.Date());
dateval = table.getModel().getValueAt(row, 1);
String datevalStr = df.format(dateval);
if (datevalStr.equals(todayStr)) {
setForeground(Color.red);
}
drawn[column].add(Integer.toString(row));// mark row as rendered
} catch (Exception e) {
e.getMessage();
return null;
}
return this;
}