JtableとJTreeの表記例コード
まず、JtableとJTreeの基本概念とよく使われる構造方法を見てみます。
一:表(JTable):
1.基本概念:
テーブル(JTable)はSwingによって新たに増加したコンポーネントで、主にデータを表の形で表示するために、大きなデータを表示するための簡単な仕組みを提供します。
2.一般的な構造方法:
*JTable():システムのデフォルトモデルを使って、JTableの例を作成します。
*JTable(int numRows,int numColumns):DefaultTable Table指定行、列を使用した空の表を作成します。
*JTable(Object[][]rowData,Object[]コロムnNames):二次元データを表示するテーブルを作成します。
表の列名配列と表のデータ配列を直接使用して表を作成できます。
*JTable(Table Model dm):指定データモードとデフォルトフィールドモードのJTableの例を作成します。
データモデルクラスのオブジェクトでデータを保存しますが、テーブルモデルはテーブルの列名配列とテーブルのデータ配列で作成されます。
二:ツリー(JTree):
1.基本概念:
ツリー(JTree):階層データセットを輪郭として表示するコントロールです。
2.一般的な構造方法:
JTree():モデル例のあるJTreeを返します。
JTree(Object[]value):JTreeに戻り、配列の各要素を表示されない新しいルートノードのサブノードとして指定します。
//このコンストラクタだけが複数のルートノードを作成できます。
JTree(Object[]value):JTreeに戻り、配列の各要素を表示されない新しいルートノードのサブノードとして指定します。
JTree(Tree Node root):JTreeに戻り、指定されたTree Nodeをそのルートとして表示します。
JTree(Tree Node root、bolean asks AllowsChildren):JTreeに戻り、指定されたTree Nodeをそのルートとして、
ルートノードが指定された方法で表示され、ノードがリーフノードであるかどうかを判定する(trueはサブノードを追加し、サブノードを追加するように設定します。
サンプルコード:
jdbc部分は「BaseJDBCとCRUDDAOの書き方の実例コード」を参照してください。
本論文では、JtableとJTreeの表記例コードについての内容はここまでです。ご協力をお願いします。もし皆さんが何か質問があれば、メッセージをください。ここでも私たちのサイトを応援してくれてありがとうございます。
一:表(JTable):
1.基本概念:
テーブル(JTable)はSwingによって新たに増加したコンポーネントで、主にデータを表の形で表示するために、大きなデータを表示するための簡単な仕組みを提供します。
2.一般的な構造方法:
*JTable():システムのデフォルトモデルを使って、JTableの例を作成します。
*JTable(int numRows,int numColumns):DefaultTable Table指定行、列を使用した空の表を作成します。
*JTable(Object[][]rowData,Object[]コロムnNames):二次元データを表示するテーブルを作成します。
表の列名配列と表のデータ配列を直接使用して表を作成できます。
*JTable(Table Model dm):指定データモードとデフォルトフィールドモードのJTableの例を作成します。
データモデルクラスのオブジェクトでデータを保存しますが、テーブルモデルはテーブルの列名配列とテーブルのデータ配列で作成されます。
二:ツリー(JTree):
1.基本概念:
ツリー(JTree):階層データセットを輪郭として表示するコントロールです。
2.一般的な構造方法:
JTree():モデル例のあるJTreeを返します。
JTree(Object[]value):JTreeに戻り、配列の各要素を表示されない新しいルートノードのサブノードとして指定します。
//このコンストラクタだけが複数のルートノードを作成できます。
JTree(Object[]value):JTreeに戻り、配列の各要素を表示されない新しいルートノードのサブノードとして指定します。
JTree(Tree Node root):JTreeに戻り、指定されたTree Nodeをそのルートとして表示します。
JTree(Tree Node root、bolean asks AllowsChildren):JTreeに戻り、指定されたTree Nodeをそのルートとして、
ルートノードが指定された方法で表示され、ノードがリーフノードであるかどうかを判定する(trueはサブノードを追加し、サブノードを追加するように設定します。
サンプルコード:
package com.jTablehomework;
import java.awt.*;
import java.lang.reflect.Field;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.Vector;
import javax.swing.*;
import com.dao.CRUDDAO;
import com.entry.Login;
/**
*
* @author zzy
*
* 2016 12 1 1:52:29
*/
public class JTableDemo extends JFrame {
private JScrollPane jsp;
private JTable jt;
private DefaultTableModel tableModel;
public static void main(String[] args) {
new JTableDemo();
}
public JTableDemo() {
init();
setSize(400, 500);
setLocationRelativeTo(null);
setVisible(true);
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
}
private void init() {
Container con = getContentPane();
con.setLayout(new BorderLayout());
createJTable(con);
}
public void createJTable(Container con) {
JLabel jl = new JLabel(" ");
jl.setHorizontalAlignment(SwingConstants.CENTER);
addData();
jt = new JTable(tableModel) {
@Override
public boolean isCellEditable(int row, int column) {
return false;
}
};
System.out.println(jt.getName());
//
jt.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
int selectRow = jt.getSelectedRow();
// System.out.println(selectRow);
// int selectcow = jt.getSelectedColumn();
for (int i = 0; i < jt.getColumnCount(); i++) {
System.out.print(jt.getColumnName(i) + ":");
System.out.print(jt.getValueAt(selectRow, i) + "\t");
}
System.out.println();
// System.out.println(selectcow);
// System.out.println(tableModel.getValueAt(selectRow,
// selectcow));
Vector v = tableModel.getDataVector();
}
});
jt.setRowHeight(30);//
jt.setSelectionForeground(Color.red);//
jsp = new JScrollPane(jt);
jsp.setViewportView(jt);
con.add(jl, BorderLayout.NORTH);
con.add(jsp, BorderLayout.CENTER);
}
public void addData() {
List<Login> list = getData();
Field[] field = Login.class.getDeclaredFields();
/**
*
*/
Object columnNames[] = new Object[field.length];
for (int i = 0; i < field.length; i++) {
columnNames[i] = field[i].getName();
}
/**
*
*/
Object rowData[][] = new Object[list.size()][];
for (int i = 0; i < list.size(); i++) {
Login l = list.get(i);
Object ob[] = new Object[field.length];
for (int j = 0; j < field.length; j++) {
field[j].setAccessible(true);
try {
ob[j] = field[j].get(l);
} catch (IllegalArgumentException e) {
e.printStackTrace();
System.out.println(" ");
} catch (IllegalAccessException e) {
e.printStackTrace();
System.out.println(" ");
}//
rowData[i] = ob;
}
}
tableModel = new DefaultTableModel(rowData, columnNames);
}
public List<Login> getData() {
String sql = "select * from Login";
Map<String, Object[]> m = new LinkedHashMap<String, Object[]>();
m.put(sql, null);
return new CRUDDAO<Login>(Login.class).selectAll(m).get(1);
}
}
本体タイプのjtreeを自分で作成したクリックイベントは、switchに検索語句と実体類を入力すればいいです。jdbc部分は「BaseJDBCとCRUDDAOの書き方の実例コード」を参照してください。
本論文では、JtableとJTreeの表記例コードについての内容はここまでです。ご協力をお願いします。もし皆さんが何か質問があれば、メッセージをください。ここでも私たちのサイトを応援してくれてありがとうございます。