度々度々申し訳ないです
ファイルの情報(ファイル名、更新日時、パスなど)が入ったArrayListの情報をJTableに出力?したいのですが、だんだんArrayListの要素数(ファイルの数)そふやしていくのでその都度JTableを更新したいです。
前別の質問で答えてくれた方はfire~というメソッド(fireModelChangedメソッドと勝手に判断)を使って、更新しなければいけないと言っていたのですが、使い方がいまいちわかりません。
fireTableChangedとtableChangedの関係というか,それが何なのかさえわかりません。調べ方が悪いのか......
よければそこら辺教えてください。
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
fire~というメソッド
といったのは、いくつか種類があり、それぞれ状況によって使い分ける必要があるためです。
いまはちょっと資料が見れないので詳細には記述できませんが、
・テーブルの構造そのものが変わった場合
・行が増えたり減ったりした場合
・特定のセルの表示内容に変更があった場合
など、状況による使い分けが必要です。
適切なものを使わないと、更新が反映されなかったり、
画面がちらついたり、選択範囲かがリセットされたり
などの弊害がでてきます。
まあ、細かいことを気にしなければ、テーブル構造の変化の通知をすれば、
とりあえず内容は反映されます。
それと根本的な話ですが、これらのメソッドは、イベントを発生させるものです。
例えば、ボタンを押したときの動作でActionListenerをボタンに登録し、
actionPerformedを実装し、ボタンをが押されたことを知らされますが、
これと同じようなことが起こっています。
JTableがTableModelに対しリスナー登録を行い、
TableModelがイベントをJTableに通知しています。
この回答への補足
addTableModelListenerできるのはTableModelに対してで
TableModelListenerをimplementsするのもTableModelで.......
こんがらがってしまうのです(TдT)
ActionListenerはちゃんと別のクラスにListenerをimplementsしてできたんですが。。。。
~JTableのインスタンスを生成したクラス~
table.getModel().addTableModelListener();
~別のクラス~
public class TableModel extends AbstractTableModel implements TableModelListener{
//いろいろ
@Override
public void tableChanged(TableModelEvent e) {
//ここに書いた処理が更新時に行われる
}
}
(ここまでがあってるのかわかりませんが)ここまでは来るのですが、更新のGOサインをだれが出すのかがよくわかんなくて(ここでfire~??)、今作っているプログラムではドラッグされた時に更新したいんです。
ただfireTableChangedをドラッグの処理のところに貼るんじゃもちろんダメなんでしょうけど(TдT)
ここまで教えてもらっているのにわがままというか、自分の理解力が至らないばかりに何度も申し訳ないですm(_ _)m
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【お題】絵本のタイトル
- ・【大喜利】世界最古のコンビニについて知ってる事を教えてください【投稿~10/10(木)】
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・ハマっている「お菓子」を教えて!
- ・最近、いつ泣きましたか?
- ・夏が終わったと感じる瞬間って、どんな時?
- ・10秒目をつむったら…
- ・人生のプチ美学を教えてください!!
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルVBAで、条件に一致する...
-
Labelコントロールに数字を代入...
-
エクセルVBAにおけるON TIMEメ...
-
Javaのクラスのstaticメソッド...
-
オートシェイプの位置がずれる...
-
VBA コピーが出来ません…!
-
VBAでAccessからExcelのセルフ...
-
配列のメソッド
-
Refreshメソッドの使い方
-
シリアル通信の方法(VB)
-
ByteArrayOutputStreamでの出力...
-
BasicDataSourceについて
-
双曲線タンジェントの計算
-
&(半角アンド)を扱うには?
-
アクセスVBA 時間を止める
-
VB.NET2017 の IntelliSense に...
-
「タイプ初期化子が例外をスロ...
-
staticと+=の意味を・・・
-
VBA 同じ名前のオブジェクトを...
-
同一パッケージにあるクラスが...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBAで、条件に一致する...
-
コマンドプロンプト実行後に画...
-
DataGridViewでセルクリックイ...
-
Labelコントロールに数字を代入...
-
エクセルVBAにおけるON TIMEメ...
-
javascriptからjavaを呼び出したい
-
mainメソッドのthrows節で設定...
-
Refreshメソッドの使い方
-
配列のメソッド
-
final修飾子を使っているのに、...
-
VBPをダブルクリックするとたま...
-
ウィンドウを最前面にできません
-
JSPで<SELECT>の中にDBから持っ...
-
【sendkeysメソッドが動かずに...
-
Excel VBA でExcelを終了したい...
-
VB.netで、シリアル通信のタイ...
-
Application.Wait の参照設定
-
Excel VBA シェイプの原型のサ...
-
onClickで関数呼出し後に、結果...
-
drawStringで文字間隔の調整
おすすめ情報