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

com.jidesoft.swing.SidePane Maven / Gradle / Ivy

/*
 * @(#)SidePane.java
 *
 * Copyright 2002 JIDE Software Inc. All rights reserved.
 */
package com.jidesoft.swing;

import com.jidesoft.plaf.LookAndFeelFactory;
import com.jidesoft.plaf.SidePaneUI;
import com.jidesoft.plaf.UIDefaultsLookup;

import javax.accessibility.Accessible;
import javax.accessibility.AccessibleContext;
import javax.accessibility.AccessibleRole;
import javax.accessibility.AccessibleStateSet;
import javax.swing.*;
import java.awt.event.MouseEvent;
import java.util.ArrayList;
import java.util.List;

/**
 * SidePane is a component that can display several buttons
 * horzontally or vertically. It usually attaches to side of
 * a JFrame.
 * 

* Buttons in SidePane can be grouped. Each group is called {@link SidePaneGroup}. * Each button in the group is called {@link SidePaneItem}. */ public class SidePane extends JPanel implements SwingConstants, Accessible { /** * A list holds SideGroup */ private final List _groups = new ArrayList(); /** * the side which this component is attached to. * Possible values are:

    *
  • SwingConstants.NORTH *
  • SwingConstants.SOUTH *
  • SwingConstants.WEST *
  • SwingConstants.EAST *
*/ private int _attachedSide; /** * if action is fired when mouse rollover. */ private boolean _rollover = true; /** * @see #getUIClassID * @see #readObject */ private static final String uiClassID = "SidePaneUI"; /** * Constructor thats takes the side which this component is attached to. * * @param attachedSide the side which this component is attached to. * Possible values are:
    *
  • SwingConstants.NORTH *
  • SwingConstants.SOUTH *
  • SwingConstants.WEST *
  • SwingConstants.EAST *
* @throws IllegalArgumentException if the value is not one of NORTH, SOUTH, WEST, or EAST. */ public SidePane(int attachedSide) { setAttachedSide(attachedSide); // I'm registered to do tool tips so we can draw tips for the renderers ToolTipManager toolTipManager = ToolTipManager.sharedInstance(); toolTipManager.registerComponent(this); } /** * Returns the UI object which implements the L&F for this component. * * @return a TabbedPaneUI object * @see #setUI */ @Override public SidePaneUI getUI() { return (SidePaneUI) ui; } /** * Sets the UI object which implements the L&F for this component. * * @param ui the new UI object * @see javax.swing.UIDefaults#getUI */ public void setUI(SidePaneUI ui) { super.setUI(ui); } /** * Resets the UI property to a value from the current look and feel. * * @see javax.swing.JComponent#updateUI */ @Override public void updateUI() { if (UIDefaultsLookup.get(uiClassID) == null) { LookAndFeelFactory.installJideExtension(); } setUI((SidePaneUI) UIManager.getUI(this)); } /** * Returns the name of the UI class that implements the * L&F for this component. * * @return the string "TabbedPaneUI" * @see javax.swing.JComponent#getUIClassID * @see javax.swing.UIDefaults#getUI */ @Override public String getUIClassID() { return uiClassID; } /** * Adds a SidePaneGroup to this component. * Do nothing if there is nothing in the group. * * @param group the group to be added */ public void addGroup(SidePaneGroup group) { getGroups().add(group); } /** * Removes a SidePaneGroup from this component. * * @param group the group to be removed */ public void removeGroup(SidePaneGroup group) { getGroups().remove(group); } /** * Removes a SidePaneGroup at a spefific index from this component. * * @param index position of the group to be removed */ public void removeGroup(int index) { removeGroup(getGroups().get(index)); } /** * Gets the list of groups in this components. * * @return the list of groups */ public List getGroups() { return _groups; } /** * Gets attached side. * * @return the attached side */ public int getAttachedSide() { return _attachedSide; } /** * Sets the attached side. It will call updateUI automatically. * Possible values are:
    *
  • SwingConstants.NORTH *
  • SwingConstants.SOUTH *
  • SwingConstants.WEST *
  • SwingConstants.EAST *
*

* Note: Please call this method before this component is rendered on screen. * * @param attachedSide the attached side * @throws IllegalArgumentException if the value is not one of valid values */ public void setAttachedSide(int attachedSide) { if (attachedSide != SwingConstants.NORTH && attachedSide != SwingConstants.SOUTH && attachedSide != SwingConstants.WEST && attachedSide != SwingConstants.EAST) { throw new IllegalArgumentException("illegal attached side: must be NORTH, SOUTH, WEST, or EAST"); } _attachedSide = attachedSide; updateUI(); } /** * Is the side pane expand when mouse moves over? * * @return if true, side pane will expand when mouse moves over. */ public boolean isRollover() { return _rollover; } /** * Set if the side pane expand when mouse moves over. * * @param rollover the flag */ public void setRollover(boolean rollover) { _rollover = rollover; updateUI(); } @Override public String getToolTipText(MouseEvent event) { if (getUI() != null && !isRollover()) { int index = getUI().getSelectedItemIndex(event.getPoint()); if (index != -1) { SidePaneItem item = getUI().getItemForIndex(index); if (item != null && item.getComponent() instanceof JComponent) { return ((JComponent) item.getComponent()).getToolTipText(); } } } return null; } /** * Gets the AccessibleContext associated with this JToolBar. * For tool bars, the AccessibleContext takes the form of an * AccessibleJToolBar. * A new AccessibleJToolBar instance is created if necessary. * * @return an AccessibleJToolBar that serves as the * AccessibleContext of this JToolBar */ @Override public AccessibleContext getAccessibleContext() { if (accessibleContext == null) { accessibleContext = new AccessibleSidePane(); } return accessibleContext; } /** * This class implements accessibility support for the * SidePane class. It provides an implementation of the * Java Accessibility API appropriate to side pane user-interface elements. */ protected class AccessibleSidePane extends AccessibleJPanel { private static final long serialVersionUID = -6914188774912169441L; /** * Get the state of this object. * * @return an instance of AccessibleStateSet containing the current * state set of the object * @see javax.accessibility.AccessibleState */ @Override public AccessibleStateSet getAccessibleStateSet() { return super.getAccessibleStateSet(); } /** * Get the role of this object. * * @return an instance of AccessibleRole describing the role of the object */ @Override public AccessibleRole getAccessibleRole() { return AccessibleRole.PAGE_TAB_LIST; // consider it as a tab list } } // inner class AccessibleSidePane }