HTMLEditorKitを適用したJEditorPaneのフォームにコンポーネントを表示する
Total: 2091, Today: 1, Yesterday: 1
Posted by aterai at
Last-modified:
Summary
HTMLEditorKitを適用したJEditorPaneのフォームにinputやselectタグで表示可能なコンポーネントをテストします。
Screenshot

Advertisement
Source Code Examples
JEditorPane editor = new JEditorPane();
HTMLEditorKit kit = new HTMLEditorKit();
kit.setAutoFormSubmission(false);
editor.setEditorKit(kit);
editor.setEditable(false);
editor.addHyperlinkListener(e -> {
if (e instanceof FormSubmitEvent) {
String data = ((FormSubmitEvent) e).getData();
String charset = Charset.defaultCharset().toString();
try {
System.out.println(URLDecoder.decode(data, charset));
} catch (UnsupportedEncodingException ex) {
UIManager.getLookAndFeel().provideErrorFeedback(editor);
ex.printStackTrace();
}
}
});
editor.setText(makeHtml());
// ...
private static String makeHtml() {
ClassLoader cl = Thread.currentThread().getContextClassLoader();
String path = "example/16x16.png";
String src = Optional.ofNullable(cl.getResource(path)).map(URL::toString).orElse("not found");
// https://docs.oracle.com/javase/8/docs/api/javax/swing/text/html/FormView.html
return String.join(
"\n",
"<html><body><form id='form1' action='#'>",
"<div>Username: <input type='text' id='username' name='username'></div>",
"<div>Password: <input type='password' id='password' name='password'></div>",
"<input type='submit' value='Submit'>",
"</form><br/><hr/>",
"<form id='form2' action='#'>",
"<div>button: <input type='button' value='JButton'></div>",
"<div>checkbox: <input type='checkbox' id='checkbox1' name='checkbox1'></div>",
"<div>image: <input type='image' id='image1' name='image1' src='" + src + "'></div>",
"<div>password: <input type='password' id='password1' name='password1'></div>",
"<div>radio: <input type='radio' id='radio1' name='radio1'></div>",
"<div>reset: <input type='reset' id='reset1' name='reset1'></div>",
"<div>submit: <input type='submit' id='submit1' name='submit1'></div>",
"<div>text: <input type='text' id='text1' name='text1'></div>",
"<div>file: <input type='file' id='file1' name='file1'></div>",
"<div><isindex id='search1' name='search1' action='#'></div>",
"<div><isindex id='search2' name='search2' prompt='search: ' action='#'></div>",
"</form><br/><hr/>",
"<form id='form3' action='#'>",
"<div><select name='select1' size='5' multiple>",
" <option value='' selected='selected'>selected</option>",
" <option value='option1'>option1</option>",
" <option value='option2'>option2</option>",
"</select></div><br/>",
"<div><select name='select2'>",
" <option value='option0'>option0</option>",
" <option value='option1'>option1</option>",
" <option value='option2'>option2</option>",
"</select></div><br/>",
"<div><textarea name='textarea1' cols='50' rows='5'></div>",
"</form>",
"</body></html>");
}
View in GitHub: Java, KotlinDescription
<input type='button' ...>空白になるJButtonが使用されるtype属性がbuttonの場合はドキュメントに記述されているがソースコードでは実装されていない
<input type='checkbox' ...>JCheckBoxが使用されるchecked属性で選択状態になる
<input type='radio' ...>JRadioButtonが使用されるchecked属性で選択状態になる
<input type='image' ...>JButtonが使用されるsrc属性で画像ファイルのURLが指定可能- クリック座標が取得可能
<input type='password' ...>JPasswordFieldが使用される
<input type='text' ...>JTextFieldが使用される
<input type='reset' ...>JButtonが使用されるvalue属性でボタンラベルが変更可能
<input type='submit' ...>JButtonが使用されるvalue属性でボタンラベルが変更可能
<input type='file' ...>JTextFieldとJButtonが使用されるJButtonをクリックするとJFileChooserが開き、選択したファイルのフルパスがJTextFieldに表示される
<isindex prompt='...' action='#' ...>JLabelとJTextFieldが使用されるJLabelのテキストはprompt属性で指定、またはUIManager.put("IsindexView.prompt", "Search: ")などで設定可能
<select ...>size属性が1以上、またはmultiple属性が存在する場合はJScrollPane内に配置されたJListが使用される
<select ...>size属性が1、または存在しない場合はJComboBoxが使用される
<textarea ...>JScrollPane内に配置されたJTextAreaが使用されるrows、cols属性でJTextAreaの行数と列数を指定可能
Reference
- FormView (Java Platform SE 8 )
- 日本語ドキュメントでは
select要素、size属性、multiple属性などが次のように翻訳されてしまい少しわかりづらい - 「選択、サイズは> 1、または複数の属性を定義」
- 日本語ドキュメントでは
- JEditorPaneに表示されたフォームからの送信データを取得する