SQLの窓

2017年06月03日


Swing の JTable に 1) WEBのJSON2次元配列。2) WEB の JSON配列 を取り込んで表示する( Google Gson と okhttp を使用 )



環境準備

Eclipse は Pleiades の Neon です。Swing を使用する為の WindowBuilder のインストールとプロジェクト作成は、▼ 以下のリンク先を参照して下さい。

Pleiades All in One(NEON) で、Windows アプリを作成する手順( WindowBuilder + Swing デザイナー or SWT デザイナー[JFace] )

WEB へのアクセスは okhttp を使用します。ライブラリは MAVEN で取り込みます。okhttp は okio に依存しますが、リポジトリのファイルが壊れている場合は、okio の dependency も記述して、旧バージョンを順に試すといいでしょう。

JSON 文字列の扱いは、Google Gson を使用します

pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>WinApp</groupId>
  <artifactId>WinApp</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  
  <dependencies>
    <dependency>
      <groupId>com.google.code.gson</groupId>
      <artifactId>gson</artifactId>
      <version>2.8.0</version>
    </dependency>
    <dependency>
      <groupId>com.squareup.okhttp3</groupId>
      <artifactId>okhttp</artifactId>
      <version>3.8.0</version>
    </dependency>    
  </dependencies>
  
  <build>
    <sourceDirectory>src</sourceDirectory>
    <plugins>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.5.1</version>
        <configuration>
          <source>1.8</source>
          <target>1.8</target>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>
MAVEN プロジェクトへの変更は、プロジェクトを右クリックして『構成』から、選択できます

JTable は表示のみ対応した、JTableUnit と言うクラスを作成して使用しています。

JTableUnit
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableColumn;

public class JTableUnit extends JTable {
	
	private JScrollPane _scrollPane;

	public JTableUnit( ) {
		super();
		_scrollPane = new JScrollPane(this);
	}
	
	@Override
	public boolean isCellEditable(int row, int column) {
		return false;
	}	
	
	public JScrollPane getScrollPane() {
		return _scrollPane; 
	}

	// ********************
	// 初期化
	// ********************
	public void reset() {

		DefaultTableModel dtm = (DefaultTableModel) this.getModel();
		dtm.setRowCount(0);
		
		int cols = this.getColumnCount();

		for( int i = cols-1; i >= 0; i-- ) {
			this.removeColumn((this.getColumnModel()).getColumn(i));
		}
		
		// データモデルも初期化
		dtm.setColumnCount(0);

	}
	// ********************
	// 行を全て削除
	// ********************
	public void clear(){
		DefaultTableModel dtm = (DefaultTableModel) this.getModel();
		dtm.setRowCount(0);
	}
	public void addColumn(String name) {
		DefaultTableModel dtm = (DefaultTableModel) this.getModel();
		dtm.addColumn(name);
	}
	public void setColumnTitle(String name,String title) {
		TableColumn tc = this.getColumn(name);
		 tc.setHeaderValue(title);
		 tc.setIdentifier(name);
	}
	public void addRow() {
		DefaultTableModel dtm = (DefaultTableModel) this.getModel();
		Object[] obj  = null;
		dtm.addRow(obj);
	}
	public void setColumn(int row, int col, String data) {
		this.setValueAt( data, row,  col );
	}
}


前提条件

JSON データは utf-8 です。

WEB 上の2次元配列データは https://lightbox.sakura.ne.jp/demo/json/syain_array.php です。

WEB 上の通常 JSON配列データは https://lightbox.sakura.ne.jp/demo/json/syain_json.php です。

3番目の処理では、JSON データのフォーマットに合わせたクラス(Syain) を作成して使用しています

public class Syain {

	String 社員コード;
	String 氏名;
	String フリガナ;
	String 所属;
	String 性別;
	String 給与;
	String 手当;
	String 管理者;

	String 作成日;
	String 更新日;
	
}


処理

import java.awt.BorderLayout;
import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.IOException;
import java.util.Collection;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Set;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.border.EmptyBorder;

import com.google.gson.Gson;

import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;

public class Main extends JFrame {

	private JPanel contentPane;
	private JTableUnit table;
	private JPanel panel;

	public static void main(String[] args) {
		EventQueue.invokeLater(new Runnable() {
			public void run() {
				try {
					Main frame = new Main();
					frame.setVisible(true);
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
		});
	}

	public Main() {
		setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		setBounds(100, 100, 1000, 700);
		contentPane = new JPanel();
		contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
		setContentPane(contentPane);
		contentPane.setLayout(null);

		JButton buttonArray = new JButton("2次元配列");
		buttonArray.setBounds(10, 10, 112, 21);
		buttonArray.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {

				loadWebJsonArray();

			}
		});
		contentPane.add(buttonArray);

		JButton buttonProp = new JButton("JSONプロパティでタイトル");
		buttonProp.setBounds(134, 10, 218, 21);
		buttonProp.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {

				loadWebJson();

			}
		});
		contentPane.add(buttonProp);
		
		JButton buttonFix = new JButton("タイトルを内部で固定");
		buttonFix.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				
				loadWebJsonFix();
				
			}
		});
		buttonFix.setBounds(364, 10, 180, 21);
		contentPane.add(buttonFix);

		JButton buttonClear = new JButton("行クリア");
		buttonClear.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				table.clear();
			}
		});
		buttonClear.setBounds(574, 10, 150, 21);
		contentPane.add(buttonClear);

		panel = new JPanel();
		panel.setBounds(12, 52, 960, 600);
		panel.setLayout(new BorderLayout(0, 0));
		contentPane.add(panel);

		table = new JTableUnit();
		panel.add(table.getScrollPane());

	}

	// *************************
	// 2次元配列
	// *************************
	private void loadWebJsonArray(){

		table.reset();

		String url = "https://lightbox.sakura.ne.jp/demo/json/syain_array.php";
		String result ="[\"error\"]";
		OkHttpClient client = new OkHttpClient();
		Request.Builder builder = new Request.Builder();
		builder.url(url);
		Request request = builder.build();

		Response response = null;
		try {
			response = client.newCall(request).execute();
			result = response.body().string();
		}
		catch (IOException e) {
			e.printStackTrace();
		}

		Gson gson = new Gson();
		String[][] data = gson.fromJson(result, String[][].class);

		int line_count = -1;
		int col_count = 0;
		for( String[] row : data ) {

			// 初回( タイトル部分 )
			if ( line_count == -1 ) {
				col_count = 0;
				for( String col : row ) {
					table.addColumn(String.format("col%d", col_count) );
					col_count++;
				}
				col_count = 0;
				for( String col : row ) {
					table.setColumnTitle(String.format("col%d", col_count), col );
					col_count++;
				}
				line_count++;

				// タイトル部分が一行あるので、次のデータをすぐに読む
				continue;
			}

			// 2回目以降( データ部分 )

			// 空行の追加
			table.addRow();
			col_count = 0;
			for( String col : row ) {
				// line_count に、
				table.setColumn(line_count, col_count, col );
				col_count++;
			}
			line_count++;
		}

	}

	// *************************
	// JSONプロパティでタイトル
	// *************************
	private void loadWebJson(){

		table.reset();

		String url = "https://lightbox.sakura.ne.jp/demo/json/syain_json.php";
		String result ="[\"error\"]";
		OkHttpClient client = new OkHttpClient();
		Request.Builder builder = new Request.Builder();
		builder.url(url);
		Request request = builder.build();

		Response response = null;
		try {
			response = client.newCall(request).execute();
			result = response.body().string();
		}
		catch (IOException e) {
			e.printStackTrace();
		}

		Gson gson = new Gson();
		// キーの順序を保持する為に、LinkedHashMap を使用
		LinkedHashMap<String,String>[] data = gson.fromJson(result, LinkedHashMap[].class);

		int line_count = 0;
		int col_count = 0;
		Set<String> keyset = null;
		Collection<String> values = null;
		Iterator<String> it;
		for( LinkedHashMap<String, String> row_data : data ) {

			// 初回( タイトル部分 )
			if ( keyset == null ) {
				keyset = row_data.keySet();

				col_count = 0;
				it = keyset.iterator();
				while( it.hasNext() ) {
					it.next();
					table.addColumn(String.format("col%d", col_count) );
					col_count++;
				}
				col_count = 0;
				it = keyset.iterator();
				while( it.hasNext() ) {
					String col_data = it.next();
					table.setColumnTitle(String.format("col%d", col_count), col_data );
					col_count++;
				}

			}

			// 空行の追加
			table.addRow();

			// 2回目以降( データ部分 )
			col_count = 0;
			values = row_data.values();
			it = values.iterator();
			while( it.hasNext() ) {
				String col_data = it.next();
				table.setColumn(line_count, col_count, col_data );
				col_count++;
			}
			line_count++;

		}

	}

	// *************************
	// タイトルを内部で固定
	// *************************
	private void loadWebJsonFix(){

		table.reset();
		for( int i = 0; i < 10; i++ ) {
			table.addColumn(String.format("col%d", i) );
		}
		table.setColumnTitle("col0", "社員コード");
		table.setColumnTitle("col1", "氏名");
		table.setColumnTitle("col2", "フリガナ");
		table.setColumnTitle("col3", "所属");
		table.setColumnTitle("col4", "性別");
		table.setColumnTitle("col5", "給与");
		table.setColumnTitle("col6", "手当");
		table.setColumnTitle("col7", "管理者");
		table.setColumnTitle("col8", "作成日");
		table.setColumnTitle("col9", "更新日");

		String url = "https://lightbox.sakura.ne.jp/demo/json/syain_json.php";
		String result ="[\"error\"]";
		OkHttpClient client = new OkHttpClient();
		Request.Builder builder = new Request.Builder();
		builder.url(url);
		Request request = builder.build();

		Response response = null;
		try {
			response = client.newCall(request).execute();
			result = response.body().string();
		}
		catch (IOException e) {
			e.printStackTrace();
		}

		Gson gson = new Gson();
		// データ部分のみ使用
		Syain[] data = gson.fromJson(result, Syain[].class);

		int line_count = 0;
		int col_count = 0;
		for( Syain row_data : data ) {

			// 空行の追加
			table.addRow();
			// 行データをセット
			table.setColumn(line_count, 0, row_data.社員コード );
			table.setColumn(line_count, 1, row_data.氏名 );
			table.setColumn(line_count, 2, row_data.フリガナ );
			table.setColumn(line_count, 3, row_data.所属 );
			table.setColumn(line_count, 4, row_data.性別 );
			table.setColumn(line_count, 5, row_data.給与 );
			table.setColumn(line_count, 6, row_data.手当 );
			table.setColumn(line_count, 7, row_data.管理者 );
			table.setColumn(line_count, 8, row_data.作成日 );
			table.setColumn(line_count, 9, row_data.更新日 );

			line_count++;

		}

	}

}


画面にデザイナで Panel を作成しておいて、JScrollPane 込みで作成されている JTableUnit を Panel に組み込んでいます(96、97 行)。

2番目の処理は、JSON のフォーマットに対応した クラスを使わずに、LinkedHashMap を使用して key 部分を取り出してタイトルに使用しています。

3番目の処理は、固定的な処理を行う一般的なアプリケーションで有用で、ソースの可読性が格段にアップします。


タグ:java swing JSON gson
posted by lightbox at 2017-06-03 18:25 | Comment(0) | java : Swing | このブログの読者になる | 更新情報をチェックする

Swing の JTable に 1) ローカルの CSV。2) WEB の CSV を取り込んで表示する



環境準備

Eclipse は Pleiades の Neon です。Swing を使用する為の WindowBuilder のインストールとプロジェクト作成は、▼ 以下のリンク先を参照して下さい。

Pleiades All in One(NEON) で、Windows アプリを作成する手順( WindowBuilder + Swing デザイナー or SWT デザイナー[JFace] )

WEB へのアクセスは okhttp を使用します。ライブラリは MAVEN で取り込みます。okhttp は okio に依存しますが、リポジトリのファイルが壊れている場合は、okio の dependency も記述して、旧バージョンを順に試すといいでしょう。

pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <groupId>WinApp</groupId>
  <artifactId>WinApp</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  
  <dependencies>
    <dependency>
      <groupId>com.squareup.okhttp3</groupId>
      <artifactId>okhttp</artifactId>
      <version>3.8.0</version>
    </dependency>    
  </dependencies>
  
  <build>
    <sourceDirectory>src</sourceDirectory>
    <plugins>
      <plugin>
        <artifactId>maven-compiler-plugin</artifactId>
        <version>3.5.1</version>
        <configuration>
          <source>1.8</source>
          <target>1.8</target>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>

MAVEN プロジェクトへの変更は、プロジェクトを右クリックして『構成』から、選択できます

JTable は表示のみ対応した、JTableUnit と言うクラスを作成して使用しています。

JTableUnit
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableColumn;

public class JTableUnit extends JTable {
	
	private JScrollPane _scrollPane;

	public JTableUnit( ) {
		super();
		_scrollPane = new JScrollPane(this);
	}
	
	@Override
	public boolean isCellEditable(int row, int column) {
		return false;
	}	
	
	public JScrollPane getScrollPane() {
		return _scrollPane; 
	}

	// ********************
	// 初期化
	// ********************
	public void reset() {

		DefaultTableModel dtm = (DefaultTableModel) this.getModel();
		dtm.setRowCount(0);
		
		int cols = this.getColumnCount();

		for( int i = cols-1; i >= 0; i-- ) {
			this.removeColumn((this.getColumnModel()).getColumn(i));
		}
		
		// データモデルも初期化
		dtm.setColumnCount(0);

	}
	// ********************
	// 行を全て削除
	// ********************
	public void clear(){
		DefaultTableModel dtm = (DefaultTableModel) this.getModel();
		dtm.setRowCount(0);
	}
	public void addColumn(String name) {
		DefaultTableModel dtm = (DefaultTableModel) this.getModel();
		dtm.addColumn(name);
	}
	public void setColumnTitle(String name,String title) {
		TableColumn tc = this.getColumn(name);
		 tc.setHeaderValue(title);
		 tc.setIdentifier(name);
	}
	public void addRow() {
		DefaultTableModel dtm = (DefaultTableModel) this.getModel();
		Object[] obj  = null;
		dtm.addRow(obj);
	}
	public void setColumn(int row, int col, String data) {
		this.setValueAt( data, row,  col );
	}
}


前提条件

CSV は、ローカル・WEB 共に shift_jis です。
WEB 上のデータは https://lightbox.sakura.ne.jp/demo/json/syain_csv.php です。

処理

import java.awt.BorderLayout;
import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.border.EmptyBorder;

import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;

public class Main extends JFrame {

	private JPanel contentPane;
	private JTableUnit table;
	private JPanel panel;

	public static void main(String[] args) {
		EventQueue.invokeLater(new Runnable() {
			public void run() {
				try {
					Main frame = new Main();
					frame.setVisible(true);
				} catch (Exception e) {
					e.printStackTrace();
				}
			}
		});
	}

	public Main() {
		setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
		setBounds(100, 100, 1000, 700);
		contentPane = new JPanel();
		contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
		setContentPane(contentPane);
		contentPane.setLayout(null);

		JButton buttonLocal = new JButton("ローカルCSV読込み");
		buttonLocal.setBounds(10, 10, 150, 21);
		buttonLocal.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {

				loadCsv();

			}
		});
		contentPane.add(buttonLocal);

		JButton buttonWeb = new JButton("WEBCSV読込み");
		buttonWeb.setBounds(172, 10, 150, 21);
		buttonWeb.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {

				loadWebCsv();

			}
		});
		contentPane.add(buttonWeb);

		JButton buttonClear = new JButton("行クリア");
		buttonClear.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				table.clear();
			}
		});
		buttonClear.setBounds(334, 10, 150, 21);
		contentPane.add(buttonClear);

		panel = new JPanel();
		panel.setBounds(12, 52, 960, 600);
		panel.setLayout(new BorderLayout(0, 0));
		contentPane.add(panel);

		table = new JTableUnit();
		panel.add(table.getScrollPane());



	}

	// *************************
	// ローカルCSV読込み
	// *************************
	private void loadCsv(){

		table.reset();

		try {
			FileInputStream fis = new FileInputStream("C:\\Users\\lightbox\\Documents\\社員.csv");
			InputStreamReader isr = new InputStreamReader(fis, "MS932");
			BufferedReader br = new BufferedReader(isr);

			String cols_string;
			String[] col_data = null;
			int line_count = 0;
			while ( null != (cols_string = br.readLine() ) ) {

				// 空行を無視する
				if (cols_string.equals("")) {
					continue;
				}

				// 初回( タイトル部分 )
				if ( col_data == null ) {
					col_data = cols_string.split(",");

					// addColumn と  setColumnTitle は別々に実行する必要があります
					for( int i = 0; i < col_data.length; i++ ) {
						// カラムの ID を定義しています
						table.addColumn(String.format("col%d", i) );
					}
					for( int i = 0; i < col_data.length; i++ ) {
						// カラムの ID に対してタイトル文字列をセットしています
						table.setColumnTitle(String.format("col%d", i), col_data[i] );
					}
					continue;
				}

				// 2回目以降( データ部分 )
				col_data = cols_string.split(",");

				// 空行の追加
				table.addRow();
				for( int i = 0; i < col_data.length; i++ ) {
					// 行, カラム でデータをセット
					table.setColumn(line_count, i, col_data[i] );
				}
				line_count++;
			}

			br.close();
			isr.close();
			fis.close();
		}
		catch (Exception e) {
			e.printStackTrace();
		}

	}

	// *************************
	// WEBCSV読込み
	// *************************
	private void loadWebCsv(){

		table.reset();

		String url = "https://lightbox.sakura.ne.jp/demo/json/syain_csv.php";
		String result ="[\"error\"]";
		OkHttpClient client = new OkHttpClient();
		Request.Builder builder = new Request.Builder();
		builder.url(url);
		Request request = builder.build();

		Response response = null;
		try {
			response = client.newCall(request).execute();
			result = response.body().string();
		}
		catch (IOException e) {
			e.printStackTrace();
		}

		String[] row_data = result.split("\n");
		String[] col_data = null;
		int line_count = 0;
		for( String cols_string : row_data ) {

			// 空行を無視する
			if (cols_string.equals("")) {
				continue;
			}

			// 初回( タイトル部分 )
			if ( col_data == null ) {
				col_data = cols_string.split(",");
				for( int i = 0; i < col_data.length; i++ ) {
					// カラムの ID を定義しています
					table.addColumn(String.format("col%d", i) );
				}
				for( int i = 0; i < col_data.length; i++ ) {
					// カラムの ID に対してタイトル文字列をセットしています
					table.setColumnTitle(String.format("col%d", i), col_data[i] );
				}
				continue;
			}

			// 2回目以降( データ部分 )
			col_data = cols_string.split(",");

			// 空行の追加
			table.addRow();
			col_data = cols_string.split(",");
			for( int i = 0; i < col_data.length; i++ ) {
				// 行, カラム でデータをセット
				table.setColumn(line_count, i, col_data[i] );
			}
			line_count++;

		}
	}

}

画面にデザイナで Panel を作成しておいて、JScrollPane 込みで作成されている JTableUnit を Panel に組み込んでいます(82、83 行)。

okhttp での キャラクタセットは、サーバ側から送られた Content-Type を元に response.body().string() 実行時に自動変換されます。



タグ:swing java OkHttp
posted by lightbox at 2017-06-03 17:48 | Comment(0) | java : Swing | このブログの読者になる | 更新情報をチェックする

2014年06月13日


Java : JDialog で モーダルダイアログ

概要

1) 閉じたら Dispose するように設定する
2) モーダルダイアログとして設定する
( 列挙型 Dialog.ModalityType )
※ この機能が導入されたのは、1.6(2006年12月11日)からです。
3) 表示させる( この時点で、モーダルダイアログとして動作し、終了待ちになります )

参考ページ

InputMap を使ってESCキーで閉じる( こちらの記事は 1.4 時点の記事です )

呼び出し側



JDialog 側



呼び出し部分
	private class RefAction extends AbstractAction {
		public RefAction() {
			putValue(NAME, "参照");
			putValue(SHORT_DESCRIPTION, "Some short description");
		}
		public void actionPerformed(ActionEvent e) {
			
			try {
				final Syain dialog = new Syain();
				dialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
				dialog.setModalityType(JDialog.ModalityType.APPLICATION_MODAL);
				dialog.addWindowListener(new WindowAdapter() {
					@Override
					public void windowClosing(WindowEvent e) {
						if ( dialog.isResult() ) {
							System.out.println("OKが選択されました");
							syainCode.setText(dialog.getCode());
							checkAction.actionPerformed(null);			
						}
						System.out.println("ダイアログを閉じています");
					}
				});
				dialog.setVisible(true);
				System.out.println("この行は、ダイアログが閉じられた後に実行されます");
				
			} catch (Exception ex) {
				ex.printStackTrace();
			}
			
		}
	}


JDialog を継承したクラスの内部

中のボタンの処理です。ウインドウを閉じる処理は イベントを Post して、x ボタンをクリックした事にしています。
	private class CancelAction extends AbstractAction {
		public CancelAction() {
			putValue(NAME, "キャンセル");
			putValue(SHORT_DESCRIPTION, "Some short description");
		}
		public void actionPerformed(ActionEvent e) {
			Toolkit.getDefaultToolkit().getSystemEventQueue().postEvent(new WindowEvent(Syain.this, WindowEvent.WINDOW_CLOSING));			
		}
	}
	private class OkAction extends AbstractAction {
		public OkAction() {
			putValue(NAME, "OK");
			putValue(SHORT_DESCRIPTION, "Some short description");
		}
		public void actionPerformed(ActionEvent e) {
			int row = lboxTable.getSelectedRow();
			if ( row == -1 ) {
				JOptionPane.showMessageDialog(
						contentPanel,
						"行が選択されていません",
						"エラー",
						JOptionPane.ERROR_MESSAGE);
				return;
			}
			
			code = (String) lboxTable.getColumnText(row, "COLUMN_1");
			
			result = true;
			Toolkit.getDefaultToolkit().getSystemEventQueue().postEvent(new WindowEvent(Syain.this, WindowEvent.WINDOW_CLOSING));			
		}
	}




タグ:java JDialog
posted by lightbox at 2014-06-13 00:51 | java : Swing | このブログの読者になる | 更新情報をチェックする

2012年01月12日


Eclipse( Pleiades ) Helios に、VisualEditor をインストールして、JFrame で実行するまでの全手順画像

Eclipse( Pleiades ) Helios + VisualEditor - NAVER まとめ

画像は30枚以上になりました。こういうものを作るにはうってつけの NAVER
を利用しました。いずれ自分のサイトに移すつもりではありますが、まだ確
認作業も残っているので、当分はこれで運用するつもりです。

※ 確証はありませんが、JDK は 1.6 を推奨しておきます。

bit.ly にも 『HELIOs』で登録しました

http://bit.ly/HELIOs








Java : Eclipse Galileo 3.5( +VisualEditor )のインストール
よりも簡単でいいですね。若干 Eclipse 上でのコントロールの貼り付け手順
の仕様が変わったようですが、特別問題はありません



posted by lightbox at 2012-01-12 20:01 | java : Swing | このブログの読者になる | 更新情報をチェックする

2009年11月06日


Java : InputMap を使って JFrame 上のキーを全て処理する

C++ で作った Windows アプリケーションで言うところの、アクセラレータキー
の処理なのですが、WEB 上の Java のサンプルはどうも違うようですし、
JDK のドキュメントの日本語も意味不明ですし、結局以下のようにすると
フォーカスがウインドウ上のどこに居ても処理できます。

問題は、ユーザがコントロールからキーイベントを親に dispatchEvent していると、
処理が2回走るようなので・・・・両方使う場合は、どちらから来たか区別できるよう
にする必要があります
( こちらに統一したほうが無難です )
AbstractAction esc_action = new AbstractAction() {
	public void actionPerformed(ActionEvent e) {
		System.out.println("ESCキーが押されました");
	}
};

InputMap imap = this.getRootPane().getInputMap(
	JComponent.WHEN_IN_FOCUSED_WINDOW
);
imap.put(KeyStroke.getKeyStroke(KeyEvent.VK_ESCAPE, 0), "ESC");
this.getRootPane().getActionMap().put("ESC", esc_action);


posted by lightbox at 2009-11-06 14:58 | java : Swing | このブログの読者になる | 更新情報をチェックする

2009年09月27日


Java : WEB 上の XML を JTable に表示

スクロールさせる為に、データを重複させています
Jtable1

Eclipse での配置例です
Jtable2

LboxTable は、こちらにあります
public class Main extends JFrame {

	private static final long serialVersionUID = 1L;
	private JPanel jContentPane = null;
	private JPanel jPanel = null;
	private LboxTable lboxTable = null;
	/**
	 * This method initializes jPanel	
	 * 	
	 * @return javax.swing.JPanel	
	 */
	private JPanel getJPanel() {
		if (jPanel == null) {
			jPanel = new JPanel();
			jPanel.setLayout(new BoxLayout(getJPanel(), BoxLayout.X_AXIS));
			jPanel.setBounds(new Rectangle(11, 67, 497, 220));
			jPanel.add(getLboxTable(), null);
		}
		return jPanel;
	}

	/**
	 * This method initializes lboxTable	
	 * 	
	 * @return lightbox.LboxTable	
	 */
	private JScrollPane getLboxTable() {
		if (lboxTable == null) {
			lboxTable = new LboxTable();

			lboxTable.addMouseListener(new java.awt.event.MouseAdapter() {
				public void mouseClicked(java.awt.event.MouseEvent e) {
					// ダブルクリックの処理
					if ( e.getClickCount() == 2 ) {
						int row = lboxTable.convertRowIndexToModel(lboxTable.rowAtPoint(e.getPoint()));
						int col = lboxTable.convertColumnIndexToModel(lboxTable.columnAtPoint(e.getPoint()));
						System.out.println(row+"/"+col);
					}
				}
			});
			lboxTable.AddColumn("COLUMN_1");
			lboxTable.AddColumn("COLUMN_2");

			lboxTable.SetColumnTitle("COLUMN_1", "タイトル");
			lboxTable.SetColumnTitle("COLUMN_2", "URL");

			lboxTable.SetColumnWidth("COLUMN_1", 150);
			lboxTable.SetColumnWidth("COLUMN_2", 320);
			
			try {
				// ターゲット
				URL url = new URL("http://winofsql.jp/exlink.xml");
				// 接続オブジェクト
				HttpURLConnection http = (HttpURLConnection)url.openConnection();
				// GET メソッド
				http.setRequestMethod("GET");
				// 接続
				http.connect();

				// XML 取得の準備
				DocumentBuilderFactory dbfactory = DocumentBuilderFactory.newInstance();
				DocumentBuilder builder = dbfactory.newDocumentBuilder();
				// InputStream から Documentオブジェクトを取得
				Document doc = builder.parse(http.getInputStream());

				// ここから先は一般的な DOM の処理
				// ルート要素
				Element root = doc.getDocumentElement();
				// System.out.println(root.getNodeName());
				
				// <row> 〜 </row>
				// getElementsByTagName が一番直感的で確実
				NodeList nl1 = root.getElementsByTagName("row");
				// 一つ目のノード
				Node nd1 = nl1.item(0);
				// System.out.println(nd1.getNodeName());
				
				// <fld3>名称</fld3>
				// Node を Element にキャストして getElementsByTagName を使う
				NodeList nl2 = ((Element)nd1).getElementsByTagName("fld3");
				NodeList nl3 = ((Element)nd1).getElementsByTagName("fld2");
				// 最初の row ブロックの fld3 の 列挙
				for( int i = 0; i < nl2.getLength(); i++ ) {

					// <fld3>
					// System.out.println((nl2.item(i)).getNodeName());
					// 要素に挟まれた値は、実際はテキストノードの中にあります
					int nRow = lboxTable.AddRow();
					lboxTable.SetColumnText(nRow, "COLUMN_1", (nl2.item(i)).getFirstChild().getNodeValue());
					lboxTable.SetColumnText(nRow, "COLUMN_2", (nl3.item(i)).getFirstChild().getNodeValue());

					nRow = lboxTable.AddRow();
					lboxTable.SetColumnText(nRow, "COLUMN_1", (nl2.item(i)).getFirstChild().getNodeValue());
					lboxTable.SetColumnText(nRow, "COLUMN_2", (nl3.item(i)).getFirstChild().getNodeValue());

				}

				// 接続解除
				http.disconnect();
			}
			catch (Exception e) {
			}
			
		}
		return lboxTable.root;
	}

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO 自動生成されたメソッド・スタブ
		SwingUtilities.invokeLater(new Runnable() {
			public void run() {
				Main thisClass = new Main();
				thisClass.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
				thisClass.setVisible(true);
			}
		});
	}

	/**
	 * This is the default constructor
	 */
	public Main() {
		super();
		initialize();
	}

	/**
	 * This method initializes this
	 * 
	 * @return void
	 */
	private void initialize() {
		this.setSize(531, 339);
		this.setContentPane(getJContentPane());
		this.setTitle("JFrame");
	}

	/**
	 * This method initializes jContentPane
	 * 
	 * @return javax.swing.JPanel
	 */
	private JPanel getJContentPane() {
		if (jContentPane == null) {
			jContentPane = new JPanel();
			jContentPane.setLayout(null);
			jContentPane.add(getJPanel(), null);
		}
		return jContentPane;
	}

}  //  @jve:decl-index=0:visual-constraint="10,10"



posted by lightbox at 2009-09-27 02:05 | java : Swing | このブログの読者になる | 更新情報をチェックする
Seesaa の各ページの表示について
Seesaa の 記事がたまに全く表示されない場合があります。その場合は、設定> 詳細設定> ブログ設定 で 最新の情報に更新の『実行ボタン』で記事やアーカイブが最新にビルドされます。

Seesaa のページで、アーカイブとタグページは要注意です。タグページはコンテンツが全く無い状態になりますし、アーカイブページも歯抜けページはコンテンツが存在しないのにページが表示されてしまいます。

また、カテゴリページもそういう意味では完全ではありません。『カテゴリID-番号』というフォーマットで表示されるページですが、実際存在するより大きな番号でも表示されてしまいます。

※ インデックスページのみ、実際の記事数を超えたページを指定しても最後のページが表示されるようです

対処としては、このようなヘルプ的な情報を固定でページの最後に表示するようにするといいでしょう。具体的には、メインの記事コンテンツの下に『自由形式』を追加し、アーカイブとカテゴリページでのみ表示するように設定し、コンテンツを用意するといいと思います。


※ エキスパートモードで表示しています

アーカイブとカテゴリページはこのように簡単に設定できますが、タグページは HTML 設定を直接変更して、以下の『タグページでのみ表示される内容』の記述方法で設定する必要があります

<% if:page_name eq 'archive' -%>
アーカイブページでのみ表示される内容
<% /if %>

<% if:page_name eq 'category' -%>
カテゴリページでのみ表示される内容
<% /if %>

<% if:page_name eq 'tag' -%>
タグページでのみ表示される内容
<% /if %>
この記述は、以下の場所で使用します


Windows
container 終わり

フリーフォントで簡単ロゴ作成
フリーフォントでボタン素材作成
フリーフォントで吹き出し画像作成
フリーフォントではんこ画像作成
ほぼ自由に利用できるフリーフォント
フリーフォントの書体見本とサンプル
画像を大きく見る為のウインドウを開くボタンの作成

Android SDK ポケットリファレンス
改訂版 Webデザイナーのための jQuery入門
今すぐ使えるかんたん ホームページ HTML&CSS入門
CSS ドロップシャドウの参考デモ
Google Hosted Libraries
cdnjs
BUTTONS (CSS でボタン)
イラストAC
ぱくたそ
写真素材 足成
フリーフォント一覧
utf8 文字ツール
右サイド 終わり
base 終わり