Como posso esconder (tornar invisível) linha na JTable?
Pergunta
Existe alguma maneira de fazê-lo?
Solução
O melhor maneira mais fácil seria para remover o elemento correspondente do modelo.
Outras dicas
Não é a classe RowFilter<DefaultTableModel, Object>
você pode usar para filtrar linhas. O DefaultTableModel pode ser substituído por seu próprio modelo. Para filtro, implementar o método
@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;
}
Ao acessar linhas, por exemplo ouvindo ListSelectionEvents, não se esqueça de traduzir o índice de linha visível para o índice de linha completa em seu modelo. Java fornece uma função para isso também:
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);
...
}
Confira Tutorial da Sun para JTables e olhar na seção de classificação e filtragem.
Você pode configurar um ArrayLists para cada coluna que são povoadas por valores filtradas e implementar estas em um renderizador personalizado. Se um inteiras células valores de linha não forem cumpridas, o renderizador de forma recursiva chama a si mesmo com a linha + 1.
se a linha de células faz critérios atender, ele é renderizado, mais ArrayList armazena os números de linha já prestados, o seu melhor explicado por exemplo, este método é no renderizador cliente estende 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;
}