モジュール java.desktop
パッケージ javax.swing

クラスRowFilter<M,I>

java.lang.Object
javax.swing.RowFilter<M,I>
型パラメータ:
M - モデルの型。たとえば PersonModel
I - 識別子の型。TableRowSorterの使用時はInteger

public abstract class RowFilter<M,I> extends Object
RowFilterは、エントリをモデルからフィルタ・リングして、ビューに表示されないようにするために使用します。 たとえば、JTableに関連付けられたRowFilterでは、特定の文字列を持つ列が含まれている行しか許可されないことがあります。 エントリの意味は、コンポーネントの型によって異なります。 たとえば、フィルタがJTableに関連付けられている場合、エントリは行を意味します。フィルタがJTreeに関連付けられている場合、エントリはノードを意味します。

サブクラスは、includeメソッドをオーバーライドして、エントリをビューに表示するかどうかを指定する必要があります。 エントリの各列の値を取得するには、Entry引数を使用できます。 次に、例として、文字列「a」で始まる値(複数可)を含むエントリだけを許可するincludeメソッドを示します。

 RowFilter<Object,Object> startsWithAFilter = new RowFilter<Object,Object>() {
   public boolean include(Entry<? extends Object, ? extends Object> entry) {
     for (int i = entry.getValueCount() - 1; i >= 0; i--) {
       if (entry.getStringValue(i).startsWith("a")) {
         // The value starts with "a", include it
         return true;
       }
     }
     // None of the columns start with "a"; return false so that this
     // entry is not shown
     return false;
   }
 };
 
RowFilterには、特定のモデルのRowFilterの作成を許可する2つの仮パラメータ型が用意されています。 たとえば、次のコードは、Person型のオブジェクトをラップする特定のモデルを示しています。 20歳以上のPersonだけが表示されます。
 RowFilter<PersonModel,Integer> ageFilter = new RowFilter<PersonModel,Integer>() {
   public boolean include(Entry<? extends PersonModel, ? extends Integer> entry) {
     PersonModel personModel = entry.getModel();
     Person person = personModel.getPerson(entry.getIdentifier());
     if (person.getAge() > 20) {
       // Returning true indicates this row should be shown.
       return true;
     }
     // Age is <= 20, don't show it.
     return false;
   }
 };
 PersonModel model = createPersonModel();
 TableRowSorter<PersonModel> sorter = new TableRowSorter<PersonModel>(model);
 sorter.setRowFilter(ageFilter);
 

導入されたバージョン:
1.6
関連項目: