Swing/HyperlinkHoverEffect のバックアップ(No.1)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- Swing/HyperlinkHoverEffect へ行く。
- 1 (2017-05-25 (木) 13:45:29)
- 2 (2018-05-15 (火) 18:17:19)
- 3 (2020-05-06 (水) 18:51:20)
- 4 (2021-10-31 (日) 01:09:39)
- category: swing folder: HyperlinkHoverEffect title: JEditorPaneに表示したリンク上にカーソルが乗ったとき文字色を変更する tags: [JEditorPane, HTML, HyperlinkListener] author: aterai pubdate: 2015-11-23T04:24:22+09:00 description: JEditorPaneに表示したリンクで:hover擬似クラスのような効果を行うためのHyperlinkListenerを設定します。 image:
概要
JEditorPane
に表示したリンクで:hover
擬似クラスのような効果を行うためのHyperlinkListener
を設定します。
Screenshot
Advertisement
サンプルコード
editor.setEditable(false);
//@see: BasicEditorPaneUI#propertyChange(PropertyChangeEvent evt) {
// if ("foreground".equals(name)) {
editor.putClientProperty(JEditorPane.HONOR_DISPLAY_PROPERTIES, Boolean.TRUE);
editor.addHyperlinkListener(new HyperlinkListener() {
@Override public void hyperlinkUpdate(HyperlinkEvent e) {
if (e.getEventType() == HyperlinkEvent.EventType.ENTERED) {
setElementColor(e.getSourceElement(), "red");
} else if (e.getEventType() == HyperlinkEvent.EventType.EXITED) {
setElementColor(e.getSourceElement(), "blue");
} else if (e.getEventType() == HyperlinkEvent.EventType.ACTIVATED) {
Toolkit.getDefaultToolkit().beep();
}
//??? call BasicTextUI#modelChanged() ???
editor.setForeground(Color.WHITE);
editor.setForeground(Color.BLACK);
}
});
View in GitHub: Java, Kotlin解説
- JLabelで表示するHtmlアンカータグの文字色を変更するで、
StyleSheet
にaddRule("a:hover{color:#FF0000;}")
としても効果がない HyperlinkListener
をJEditorPane
に設定し、HyperlinkEvent.EventType.ENTERED
イベントでリンク文字色を赤に変更、HyperlinkEvent.EventType.EXITED
イベントで青に戻すよう設定- リンク文字色の変更は
HyperlinkEvent
から取得したElement
の属性に、以下のようにaddAttribute(HTML.Attribute.COLOR, color)
メソッドを使用して設定
private void setElementColor(Element element, String color) {
AttributeSet attrs = element.getAttributes();
Object o = attrs.getAttribute(HTML.Tag.A);
if (o instanceof MutableAttributeSet) {
MutableAttributeSet a = (MutableAttributeSet) o;
a.addAttribute(HTML.Attribute.COLOR, color);
}
}