Swing/HighlightTextForeground のバックアップ(No.4)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- Swing/HighlightTextForeground へ行く。
- category: swing folder: HighlightTextForeground title: JTextPaneで検索結果のハイライト表示と文字色変更を同時に行う tags: [JTextPane, StyledDocument, Style, Highlighter, Matcher, Pattern] author: aterai pubdate: 2014-11-10T00:02:14+09:00 description: Highlighter.HighlightPainterを使用したハイライト表示では文字色を変更することが出来ないので、JTextPaneにStyleを適用してこれを同時に行います。 image:
概要
Highlighter.HighlightPainter
を使用したハイライト表示では文字色を変更することが出来ないので、JTextPane
にStyle
を適用してこれを同時に行います。
Screenshot
Advertisement
サンプルコード
StyledDocument doc = textPane.getStyledDocument();
Style def = doc.getStyle(StyleContext.DEFAULT_STYLE);
Style htf = doc.addStyle("highlight-text-foreground", def);
StyleConstants.setForeground(htf, new Color(0xFFDDFF));
//...
//clear the previous highlight:
Highlighter highlighter = textPane.getHighlighter();
for (Highlighter.Highlight h: highlighter.getHighlights()) {
doc.setCharacterAttributes(
h.getStartOffset(), h.getEndOffset() - h.getStartOffset(), def, true);
}
highlighter.removeAllHighlights();
//...
//match highlighting:
Highlighter.Highlight hh = highlighter.getHighlights()[current];
highlighter.removeHighlight(hh);
highlighter.addHighlight(
hh.getStartOffset(), hh.getEndOffset(), currentPainter);
doc.setCharacterAttributes(
hh.getStartOffset(), hh.getEndOffset() - hh.getStartOffset(), s, true);
scrollToCenter(textPane, hh.getStartOffset());
View in GitHub: Java, Kotlin解説
上記のサンプルでは、JTextAreaでハイライト付き検索を行うに、以下のような変更を追加することで、検索結果のハイライト表示と文字色変更を同時に行っています。
StyledDocument
に名称"regular"
でStyle
を追加StyledDocument
に、名称が"highlight-text-foreground"
で文字色のみデフォルトから変更したStyle
を追加- 検索結果のハイライト(背景)と同時に、
StyledDocument#getStyle("highlight-text-foreground")
で取得したStyle
をStyledDocument#setCharacterAttributes(...)
で、上書き追加- 現在の対象になっている検索結果以外は、
StyledDocument#getStyle("highlight-text-foreground")
のStyle
で文字色を元に元に戻す
- 現在の対象になっている検索結果以外は、
参考リンク
- JTextAreaでハイライト付き検索を行う
- JTextPaneでキーワードのSyntaxHighlight
- Highlighterで文字列をハイライト
- こちらのコメントからソースコードを移動して、この記事を作成