9

SSCCEをご覧ください。選択されていないツリーノードの背景を透明にするにはどうすればよいですか。現時点では、選択されていないノードの背景は白です。ただし、私のセルレンダラーは、選択されていない場合は不透明ではなく(選択されている場合は緑色で...何をするのか)ペイントする必要があります。SSCCEで赤く表示されている領域にはアプリケーションにグラデーションが表示されているため、最終的には、選択されていないノードを背景のないテキストにします。

    import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.awt.Container;

import javax.swing.JFrame;
import javax.swing.JScrollPane;
import javax.swing.JTree;
import javax.swing.tree.DefaultMutableTreeNode;
import javax.swing.tree.DefaultTreeCellRenderer;

public class SimpleTree extends JFrame
{
    public static void main(final String[] args)
    {
        new SimpleTree();
    }

    public SimpleTree()
    {
        super("Creating a Simple JTree");
        final Container content = this.getContentPane();
        content.setBackground(Color.RED);
        final Object[] hierarchy = { "javax.swing", "javax.swing.border", "javax.swing.colorchooser", "javax.swing.event", "javax.swing.filechooser", new Object[] { "javax.swing.plaf", "javax.swing.plaf.basic", "javax.swing.plaf.metal", "javax.swing.plaf.multi" }, "javax.swing.table",
                        new Object[] { "javax.swing.text", new Object[] { "javax.swing.text.html", "javax.swing.text.html.parser" }, "javax.swing.text.rtf" }, "javax.swing.tree", "javax.swing.undo" };
        final DefaultMutableTreeNode root = this.processHierarchy(hierarchy);
        final JTree tree = new JTree(root);
        tree.setOpaque(false);
        tree.setCellRenderer(new MyCellRenderer());
        final JScrollPane scroller = new JScrollPane(tree);
        scroller.getViewport().setOpaque(false);
        scroller.setOpaque(false);
        content.add(scroller, BorderLayout.CENTER);
        this.setSize(275, 300);
        this.setVisible(true);
    }

    /**
     * Small routine that will make node out of the first entry in the array,
     * then make nodes out of subsequent entries and make them child nodes of
     * the first one. The process is repeated recursively for entries that are
     * arrays.
     */

    private DefaultMutableTreeNode processHierarchy(final Object[] hierarchy)
    {
        final DefaultMutableTreeNode node = new DefaultMutableTreeNode(hierarchy[0]);
        DefaultMutableTreeNode child;
        for (int i = 1; i < hierarchy.length; i++)
        {
            final Object nodeSpecifier = hierarchy[i];
            if (nodeSpecifier instanceof Object[]) // Ie node with children
                child = this.processHierarchy((Object[]) nodeSpecifier);
            else
                child = new DefaultMutableTreeNode(nodeSpecifier); // Ie Leaf
            node.add(child);
        }
        return (node);
    }

    public class MyCellRenderer extends DefaultTreeCellRenderer
    {
        @Override
        public Component getTreeCellRendererComponent(final JTree tree, final Object value, final boolean sel, final boolean expanded, final boolean leaf, final int row, final boolean hasFocus)
        {
            final Component ret = super.getTreeCellRendererComponent(tree, value, sel, expanded, leaf, row, hasFocus);

            final DefaultMutableTreeNode node = ((DefaultMutableTreeNode) (value));

            this.setText(value.toString());
            if (sel)
            {
                this.setOpaque(true);
                this.setBackground(Color.GREEN);

            }
            else
            {
                this.setOpaque(false);
                this.setBackground(null);
            }
            return ret;
        }
    }
}

ここに画像の説明を入力してください

4

2 に答える 2

17

getBackgroundNonSelectionColorgetBackgroundSelectionColorおよびgetBackgroundofをオーバーライドして、次のDefaultTreeCellRendererような適切な値を返す必要があります。

public class MyCellRenderer extends DefaultTreeCellRenderer {

    @Override
    public Color getBackgroundNonSelectionColor() {
        return (null);
    }

    @Override
    public Color getBackgroundSelectionColor() {
        return Color.GREEN;
    }

    @Override
    public Color getBackground() {
        return (null);
    }

    @Override
    public Component getTreeCellRendererComponent(final JTree tree, final Object value, final boolean sel, final boolean expanded, final boolean leaf, final int row, final boolean hasFocus) {
        final Component ret = super.getTreeCellRendererComponent(tree, value, sel, expanded, leaf, row, hasFocus);

        final DefaultMutableTreeNode node = ((DefaultMutableTreeNode) (value));
        this.setText(value.toString());
        return ret;
    }
}

これは以下を生成します:

ここに画像の説明を入力してください

その他の提案:

  • イベントディスパッチスレッドでSwingコンポーネントを作成および操作します。
  • 不必要に拡張するJFrameのではなく、インスタンスを作成して使用してください。
  • 表示する前に、すべてのコンポーネントを追加した後に、正しいおよび/またはオーバーライドを使用して呼び出すsetSizeのではなく、呼び出してください。JFrameLayoutManagergetPreferredSize()pack()JFrame
  • JFrame#setDefaultCloseOperationまたはのいずれかDISPOSE_ON_CLOSEで呼び出すことを忘れないでくださいEXIT_ON_CLOSE(Guiが閉じられた後も実行を継続できるため、sをDISPOSE_XXX使用しない限り通常は推奨されます)。Timermain(String[] args)
于 2013-01-28T14:05:25.147 に答える
5

バックグラウンドの補充を避けるために、UIManager.put("Tree.rendererFillBackground", false);new SimpleTree();または後に置くだけsuper("Creating a Simple JTree");です。

于 2013-01-28T13:57:18.317 に答える