All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.pivot.wtk.content.TreeNode Maven / Gradle / Ivy

The newest version!
/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to you under the Apache License,
 * Version 2.0 (the "License"); you may not use this file except in
 * compliance with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.apache.pivot.wtk.content;

import java.net.URL;

import org.apache.pivot.wtk.media.Image;

/**
 * Default tree node implementation.
 */
public class TreeNode {
    private TreeBranch parent = null;

    private Image icon = null;
    private String text = null;
    private Object userData = null;

    public TreeNode() {
        this(null, null);
    }

    public TreeNode(Image icon) {
        this(icon, null);
    }

    public TreeNode(String text) {
        this(null, text);
    }

    public TreeNode(Image icon, String text) {
        this.icon = icon;
        this.text = text;
        this.userData = null;
    }

    public TreeBranch getParent() {
        return parent;
    }

    protected void setParent(TreeBranch parent) {
        this.parent = parent;
    }

    public Image getIcon() {
        return icon;
    }

    public void setIcon(Image icon) {
        this.icon = icon;
    }

    /**
     * Sets the tree node's icon by URL.
     * 

* If the icon already exists in the application context resource cache, * the cached value will be used. Otherwise, the icon will be loaded * synchronously and added to the cache. * * @param iconURL * The location of the icon to set. */ public void setIcon(URL iconURL) { if (iconURL == null) { throw new IllegalArgumentException("iconURL is null."); } setIcon(Image.loadFromCache(iconURL)); } /** * Sets the tree node's icon by {@linkplain ClassLoader#getResource(String) * resource name}. * * @param iconName * The resource name of the icon to set. * * @see #setIcon(URL) */ public void setIcon(String iconName) { if (iconName == null) { throw new IllegalArgumentException("iconName is null."); } ClassLoader classLoader = Thread.currentThread().getContextClassLoader(); URL url = classLoader.getResource(iconName.substring(1)); if (url == null) { throw new IllegalArgumentException("cannot find icon resource " + iconName); } setIcon(url); } public String getText() { return text; } public void setText(String text) { this.text = text; } public Object getUserData() { return userData; } public void setUserData(Object userData) { this.userData = userData; } @Override public String toString() { StringBuilder sb = new StringBuilder(); sb.append(getClass().getName()); sb.append(" ["); sb.append(text); sb.append(", "); sb.append(userData); sb.append("]"); return sb.toString(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy