お世話になります
JTableにDBからの検索結果を表示させて、そのセルを編集したときに編集したセルに対してアップデート等の処理を行いたいのですが、セルが編集されたときのイベントを取得したいのですがうまくいきません。
具体的なソース等のアドバイスよろしくお願いします。
---ソース---
TableEditListener lisner = new TableEditListener()
tableModel = new AbstractTableModel(vecResult,clmName);
tableModel.addTableModelListener(lisner);
table = new JTable(tableModel);
内部クラス
class TableEditListener implements javax.swing.event.TableModelListener{
public TableEditListener(){
}
public void tableChanged(TableModelEvent e){
System.out.println("セルの編集をしました。");
}
}
現在以上のようなソースになっています。
よろしくお願いします。
No.2ベストアンサー
- 回答日時:
aotakatakaさんはJTable自身のイベントとCellEditorのイベントを混同して
しまっているのかもしれませんね。editingStoppedはCellEditorのイベントです。
/**
* 内部テーブルクラス
*/
class ETable extends JTable{
public ETable( TableModel tableModel ){
super( tableModel );
DefaultTableColumnModel colModel = (DefaultTableColumnModel)getColumnModel();
//0番目のカラムを取得する
TableColumn col0 = colModel.getColumn( 0 );
//0番目のカラムにMyCellEditorをセットする
col0.setCellEditor( new MyCellEditor( new JTextField() ) );
}
}
/**
* CellEditor
*/
class MyCellEditor extends DefaultCellEditor{
MyCellEditor( JTextField tf ){
super( tf );
setClickCountToStart( 1 );
//MyEditorListenerを追加
addCellEditorListener( new MyEditorListener() );
}
}
/**
* CellEditorListener
*/
class MyEditorListener implements CellEditorListener{
//セルの編集が終わった時
public void editingStopped( ChangeEvent e ){
}
public void editingCanceled( ChangeEvent e ){
}
}
>MyEditorListenerをどのようにJTableに組み込んでいいのかわからず困っています。
MyEditorListenerをJTableに組み込むのではなく、MyEditorListener
を追加したMyCellEditorをJTableに組み込むというのが正解です。
CellEditorやここでは関係ありませんがCellRendererなどは覚えてしまうと
非常に便利なクラスです。是非頑張ってください。
また不明点がありましたら補足を下さい。
内部テーブルクラスを以下のように修正して
イベントを取得することができました!!
/**
* 内部テーブルクラス
*/
class ETable extends JTable{
public ETable( TableModel tableModel ){
super( tableModel );
// DefaultTableColumnModel colModel = (DefaultTableColumnModel)getColumnModel();
DefaultTableColumnModel colModel = (DefaultTableColumnModel)getColumnModel();
//0番目のカラムを取得する
for (int i=0;i<tableModel.getColumnCount();i++){
TableColumn col0 = colModel.getColumn( i );
//0番目のカラムにMyCellEditorをセットする
col0.setCellEditor( new MyCellEditor( new JTextField() ) );
}
}
public ETable( Vector rowList, Vector clmnList ){
super(rowList,clmnList);
// DefaultTableColumnModel colModel = (DefaultTableColumnModel)getColumnModel();
DefaultTableColumnModel colModel = (DefaultTableColumnModel)getColumnModel();
//0番目のカラムを取得する
for (int i=0;i<clmnList.size();i++){
TableColumn col0 = colModel.getColumn( i );
//0番目のカラムにMyCellEditorをセットする
col0.setCellEditor( new MyCellEditor( new JTextField() ) );
}
}
}
ありがとうございました。
とても勉強になりました。
No.1
- 回答日時:
TableCellEditorを使用せずに編集されたときのイベントをとるのは出来ない
かもしれませんが、編集が始まった時(正しくはカラムをクリックした時)の
イベントはとることができます。
/**
* 内部テーブルクラス
*/
class MyTable extends JTable{
public MyTable( TableModel tableModel ){
super( tableModel );
}
//カラムをクリックしたときにこのメソッドが内部的に呼ばれるので処理をここに記述する
public void valueChanged( ListSelectionEvent e ){
super.valueChanged( e );
//System.out.println("valueChanged");
}
}
TableCellEditorを使用するならもっと細かくイベントをとることができます。
編集終了のタイミングをとる場合はCellEditorListenerをimplementsした
クラスを使用するとよいと思います。
/**
* CellEditor
*/
class MyCellEditor extends DefaultCellEditor{
MyCellEditor( JTextField tf ){
super( tf );
setClickCountToStart( 1 );
//リスナー追加
addCellEditorListener( new MyEditorListener() );
}
}
/**
* CellEditorListener
*/
class MyEditorListener implements CellEditorListener{
//セルの編集が終わった時
public void editingStopped( ChangeEvent e ){
//やりたいことをここに記述する
}
public void editingCanceled( ChangeEvent e ){
}
}
JTable周辺の詳細はSUNが提供しているJavadocをご覧いただくか参考URL
を参照して下さい。わかりにくい部分がれば補足を下さい。
参考URL:http://java-house.etl.go.jp/ml/
この回答への補足
MyEditorListener をAbstractTableModelいaddListener
するということでしょうか?
いまいち
MyEditorListenerをどのようにJTableに組み込んでいいのかわからず困っています。
editingStoppedメソッドに処理を書くことはわかるのですが…
再度、助言お願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C# DatagridviewにExcelシートを反映するとエラーが出る 2 2023/05/06 17:12
- Visual Basic(VBA) VBA Userform転記のみ編集可 1 2023/06/29 11:03
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/08/08 15:45
- Visual Basic(VBA) VBAで自動集計(特定セルコピー月ごとに値貼り付け)したい。 6 2023/06/25 11:37
- Excel(エクセル) エクセルの編集オプション セル移動 2 2022/04/02 09:19
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/21 09:42
- Excel(エクセル) Excelで数式をそのままコピーしたい どうすればいいですか? 4 2022/09/16 02:16
- Excel(エクセル) 【EXCEL】=セル&セルが上手く表示できない。 7 2022/09/04 21:32
- Visual Basic(VBA) エクセルVBA エクセルを開いた後に編集可能な状態にするには? 2 2023/06/14 11:58
- C言語・C++・C# クラスのメンバ変数を基準に並べ替えをしたい 5 2022/12/25 17:40
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
c++,ある関数のクラスから別の...
-
C#にて別クラスの関数を使いたい
-
アップキャスト、ダウンキャス...
-
C#でほかのファイルにある自作...
-
関数内の変数に<summary>コメン...
-
範囲外の数値を代入したらエラ...
-
c# Undo/Redo 関係
-
a href="..." とServlet
-
java-別クラスの変数の使い方を...
-
クラス間でのデータ参照
-
C++でfriendクラスにしているの...
-
継承したクラス側のクラス名の取得
-
命名規約について
-
(クラス名.this.メソッド)って...
-
親クラスから子クラスへアクセス。
-
static変数を持ったクラスを継...
-
SwingでgetContentPaneのエラー...
-
内部クラスのインスタンスを外...
-
Java リフレクションについて
-
import と extends について
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
関数内の変数に<summary>コメン...
-
C#にて別クラスの関数を使いたい
-
c++,ある関数のクラスから別の...
-
親クラスから子クラスへアクセス。
-
C#でほかのファイルにある自作...
-
クラス間でのデータ参照
-
構造 他のクラスの構造体を別...
-
範囲外の数値を代入したらエラ...
-
ひとつのファイルにクラスは1つ?
-
C++でfriendクラスにしているの...
-
Java リフレクションについて
-
継承したクラス側のクラス名の取得
-
C# インターフェイスの実装
-
java-別クラスの変数の使い方を...
-
C#のクラスライブラリでメッセ...
-
visual studioのデザイナ画面で...
-
C# log4netの使い方
-
a href="..." とServlet
-
アップキャスト、ダウンキャス...
-
オブジェクトのデータをもとにX...
おすすめ情報