JTextAreaにLoggerのログを出力する
Total: 6529
, Today: 3
, Yesterday: 4
Posted by aterai at
Last-modified:
概要
Logger
のログ出力をJTextArea
に表示するためのOutputStream
とStreamHandler
を作成します。
サンプルコード
class TextAreaOutputStream extends OutputStream {
private final ByteArrayOutputStream buffer = new ByteArrayOutputStream();
private final JTextArea textArea;
protected TextAreaOutputStream(JTextArea textArea) {
super();
this.textArea = textArea;
}
@Override public void flush() throws IOException {
textArea.append(buffer.toString("UTF-8"));
buffer.reset();
}
@Override public void write(int b) {
buffer.write(b);
}
@Override public void write(byte[] b, int off, int len) {
buffer.write(b, off, len);
}
}
View in GitHub: Java, Kotlin解説
TextAreaOutputStream
ByteArrayOutputStream
を使用してJTextArea
に一行ずつ書き込みを行う- これを
System.setOut(new PrintStream(new TextAreaOutputStream(textArea), true, "UTF-8"));
のように標準出力ストリームに割り当てるとSystem.out.println(...)
などで改行文字が書き込まれたときにバッファのflush()
が呼び出され、textArea.append(buf.toString("UTF-8"));
メソッドでJTextArea
に文字列が追記される
TextAreaHandler
- ログ出力を上記の
TextAreaOutputStream
などに割り当てるため、StreamHandler
を継承するTextAreaHandler
を作成しLogger#addHandler(...)
で設定 StreamHandler#setEncoding(...)
でエンコーディングをUTF-8
に設定StreamHandler#publish(...)
、StreamHandler#close(...)
をオーバーライドclass TextAreaHandler extends StreamHandler { private void configure() { setFormatter(new SimpleFormatter()); try { setEncoding("UTF-8"); } catch (IOException ex) { try { setEncoding(null); } catch (IOException ex2) { // doing a setEncoding with null should always work. // assert false; ex2.printStackTrace(); } } } public TextAreaHandler(OutputStream os) { super(); configure(); setOutputStream(os); } // @see java/util/logging/ConsoleHandler.java @Override public void publish(LogRecord record) { super.publish(record); flush(); } @Override public void close() { flush(); } }
- ログ出力を上記の
参考リンク
- System.out.println() Print to JFrame | Oracle Community
- External Program Output To JTextArea - Java | Dream.In.Code
- 標準出力を JTextArea に出力する - As I like it.
- Message Console « Java Tips Weblog