SQLの窓

2020年10月11日


Java + Swing : JTable に CSV フォーマットのテキストファイルを読み込む

動作確認は、以下の環境で行っています
JDK11
✅ Visual Studio Code + Java Extension Pack
テキストファイルの入力は行毎に読み込む方法で、オーソドックスな以下のクラスを使います。 ✅ FileInputStream => InputStreamReader => BufferedReader キャラクタセットの設定は InputStreamReader で行い、読み込みは BufferedReader の readLine を使用したループ処理です
while ( null != (line_buffer = br.readLine() ) ) {
	// ループ処理
}
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.InputStreamReader;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.border.EmptyBorder;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableColumn;

public class Main extends JFrame {

	private JPanel contentPane;
	private JTable 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);

		// ボタン
		JButton btnNewButton = new JButton("読み込み");
		btnNewButton.setBounds(10, 10, 91, 21);
		btnNewButton.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				
				loadCsv();
				
			}
		});
		
		contentPane.setLayout(null);
		contentPane.add(btnNewButton);
		
		panel = new JPanel();
		panel.setBounds(12, 52, 960, 600);
		panel.setLayout(new BorderLayout(0, 0));
		contentPane.add(panel);
		
		table = new JTable() {

			@Override
			public boolean isCellEditable(int row, int column) {
				return false;
			}
			
		};

		JScrollPane scrollPane = new JScrollPane(table);
		panel.add(scrollPane);
		
		scrollPane.setVerticalScrollBarPolicy(
				JScrollPane.VERTICAL_SCROLLBAR_AS_NEEDED);
		scrollPane.setHorizontalScrollBarPolicy(
				JScrollPane.HORIZONTAL_SCROLLBAR_AS_NEEDED);

	}
	
	// ********************
	// 初期化
	// ********************
	private void reset() {

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

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

	}
	// ********************
	// 行を全て削除
	// ********************
	private void clear(){
		DefaultTableModel dtm = (DefaultTableModel) table.getModel();
		dtm.setRowCount(0);
	}
	
	// ********************
	// CSV
	// ********************
	private void loadCsv(){
		
		reset();

		try {

			FileInputStream fis = new FileInputStream("c:\\app\\java20\\sample-10-12\\社員マスタ.csv");
			InputStreamReader isr = new InputStreamReader(fis, "MS932");
			BufferedReader br = new BufferedReader(isr);

			String line_buffer;
			String[] adata;
			int line_count = -1;
			while ( null != (line_buffer = br.readLine() ) ) {

				// カンマで分解
				adata = line_buffer.split(",");

				// 1行目はタイトル
				if ( line_count == -1 ) {
					int count = adata.length;
					// 先に全ての列を登録する必要があります
					for( int i = 0; i < count; i++) {
						String id = String.format("col%d", i);
						addColumn( table,  id );
					}
					// タイトル文字列の変更を行っています。
					// 変更しない場合は、タイトルは列を登録時の第二引数になります
					int i = 0;
					for( String value:  adata ) {
						String id = String.format("col%d", i++);
						setColumnTitle( table, id, value );
					}
				}
				// 2行目以降がデータ
				else {
					addRow(table);
					int i = 0;
					for( String value:  adata ) {
						setColumn( table, line_count, i++, value );
					}
				}

				line_count++;

			}
			
			br.close();
			isr.close();
			fis.close();
		}
		catch (Exception e) {
			e.printStackTrace();
		}
		
	}
	
	// ****************************
	// 列の追加	
	// ****************************
	private void addColumn(JTable table, String name) {
		DefaultTableModel dtm = (DefaultTableModel) table.getModel();
		dtm.addColumn(name);
	}
	// ****************************
	// 列のタイトル文字列変更
	// ****************************
	private void setColumnTitle(JTable table, String name,String title) {
		TableColumn tc1 = table.getColumn(name);
		 tc1.setHeaderValue(title);
		 tc1.setIdentifier(name);
	}
	// ****************************
	// 空の行追加
	// ****************************
	private void addRow(JTable table) {
		DefaultTableModel dtm = (DefaultTableModel) table.getModel();
		Object[] obj  = null;
		dtm.addRow(obj);
	}
	// ****************************
	// 指定カラムへデータをセット
	// ****************************
	private void setColumn(JTable table,int row,int col, String data) {
		table.setValueAt( data, row,  col  );
	}
	
}




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

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

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

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

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

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


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

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

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

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

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



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

CSS ドロップシャドウの参考デモ
イラストAC
ぱくたそ
写真素材 足成
フリーフォント一覧
utf8 文字ツール
右サイド 終わり
base 終わり