basicinternalframetitlepane.java
来自「Mac OS X 10.4.9 for x86 Source Code gcc」· Java 代码 · 共 1,014 行 · 第 1/2 页
JAVA
1,014 行
/* BasicInternalFrameTitlePane.java -- Copyright (C) 2004 Free Software Foundation, Inc.This file is part of GNU Classpath.GNU Classpath is free software; you can redistribute it and/or modifyit under the terms of the GNU General Public License as published bythe Free Software Foundation; either version 2, or (at your option)any later version.GNU Classpath is distributed in the hope that it will be useful, butWITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNUGeneral Public License for more details.You should have received a copy of the GNU General Public Licensealong with GNU Classpath; see the file COPYING. If not, write to theFree Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA02111-1307 USA.Linking this library statically or dynamically with other modules ismaking a combined work based on this library. Thus, the terms andconditions of the GNU General Public License cover the wholecombination.As a special exception, the copyright holders of this library give youpermission to link this library with independent modules to produce anexecutable, regardless of the license terms of these independentmodules, and to copy and distribute the resulting executable underterms of your choice, provided that you also meet, for each linkedindependent module, the terms and conditions of the license of thatmodule. An independent module is a module which is not derived fromor based on this library. If you modify this library, you may extendthis exception to your version of the library, but you are notobligated to do so. If you do not wish to do so, delete thisexception statement from your version. */package javax.swing.plaf.basic;import java.awt.Color;import java.awt.Component;import java.awt.Container;import java.awt.Dimension;import java.awt.Font;import java.awt.FontMetrics;import java.awt.Graphics;import java.awt.Insets;import java.awt.LayoutManager;import java.awt.Polygon;import java.awt.Rectangle;import java.awt.event.ActionEvent;import java.awt.event.KeyEvent;import java.beans.PropertyChangeEvent;import java.beans.PropertyChangeListener;import java.beans.PropertyVetoException;import javax.swing.AbstractAction;import javax.swing.Action;import javax.swing.Icon;import javax.swing.JButton;import javax.swing.JComponent;import javax.swing.JInternalFrame;import javax.swing.JLabel;import javax.swing.JMenu;import javax.swing.JMenuBar;import javax.swing.JMenuItem;import javax.swing.SwingConstants;import javax.swing.SwingUtilities;import javax.swing.UIDefaults;import javax.swing.UIManager;/** * This class acts as a titlebar for JInternalFrames. */public class BasicInternalFrameTitlePane extends JComponent{ /** * The Action responsible for closing the JInternalFrame. */ public class CloseAction extends AbstractAction { /** * This method is called when something closes the JInternalFrame. * * @param e The ActionEvent. */ public void actionPerformed(ActionEvent e) { if (frame.isClosable()) { try { frame.setClosed(true); } catch (PropertyVetoException pve) { } } } } /** * This Action is responsible for iconifying the JInternalFrame. */ public class IconifyAction extends AbstractAction { /** * This method is called when the user wants to iconify the * JInternalFrame. * * @param e The ActionEvent. */ public void actionPerformed(ActionEvent e) { if (frame.isIconifiable() && ! frame.isIcon()) { try { frame.setIcon(true); } catch (PropertyVetoException pve) { } } } } /** * This Action is responsible for maximizing the JInternalFrame. */ public class MaximizeAction extends AbstractAction { /** * This method is called when the user wants to maximize the * JInternalFrame. * * @param e The ActionEvent. */ public void actionPerformed(ActionEvent e) { try { if (frame.isMaximizable() && ! frame.isMaximum()) frame.setMaximum(true); else if (frame.isMaximum()) frame.setMaximum(false); } catch (PropertyVetoException pve) { } } } /** * This Action is responsible for dragging the JInternalFrame. */ public class MoveAction extends AbstractAction { /** * This method is called when the user wants to drag the JInternalFrame. * * @param e The ActionEvent. */ public void actionPerformed(ActionEvent e) { // FIXME: Implement keyboard driven? move actions. } } /** * This Action is responsible for restoring the JInternalFrame. Restoring * the JInternalFrame is the same as setting the maximum property to false. */ public class RestoreAction extends AbstractAction { /** * This method is called when the user wants to restore the * JInternalFrame. * * @param e The ActionEvent. */ public void actionPerformed(ActionEvent e) { if (frame.isMaximum()) { try { frame.setMaximum(false); } catch (PropertyVetoException pve) { } } } } /** * This action is responsible for sizing the JInternalFrame. */ public class SizeAction extends AbstractAction { /** * This method is called when the user wants to resize the JInternalFrame. * * @param e The ActionEvent. */ public void actionPerformed(ActionEvent e) { // FIXME: Not sure how size actions should be handled. } } /** * This class is responsible for handling property change events from the * JInternalFrame and adjusting the Title Pane as necessary. */ protected class PropertyChangeHandler implements PropertyChangeListener { /** * This method is called when a PropertyChangeEvent is received by the * Title Pane. * * @param evt The PropertyChangeEvent. */ public void propertyChange(PropertyChangeEvent evt) { // The title and frameIcon are taken care of during painting time. // The only other thing this will care about are the "is----izable" // properties. So we call enable actions to properly handle the // buttons and menu items for us. enableActions(); } } /** * This class acts as the MenuBar for the TitlePane. Clicking on the Frame * Icon in the top left corner will activate it. */ public class SystemMenuBar extends JMenuBar { /** * This method returns true if it can receive focus. * * @return True if this Component can receive focus. */ public boolean isFocusTransversable() { return true; } /** * This method returns true if this Component is expected to paint all of * itself. * * @return True if this Component is expect to paint all of itself. */ public boolean isOpaque() { return true; } /** * This method paints this Component. * * @param g The Graphics object to paint with. */ public void paint(Graphics g) { Icon frameIcon = frame.getFrameIcon(); if (frameIcon == null) frameIcon = BasicDesktopIconUI.defaultIcon; frameIcon.paintIcon(this, g, 0, 0); } /** * This method requests that focus be given to this Component. */ public void requestFocus() { super.requestFocus(); } } /** * This class acts as the Layout Manager for the TitlePane. */ protected class TitlePaneLayout implements LayoutManager { /** * Creates a new <code>TitlePaneLayout</code> object. */ public TitlePaneLayout() { // Do nothing. } /** * This method is called when adding a Component to the Container. * * @param name The name to reference the added Component by. * @param c The Component to add. */ public void addLayoutComponent(String name, Component c) { // Do nothing. } /** * This method is called to lay out the children of the Title Pane. * * @param c The Container to lay out. */ public void layoutContainer(Container c) { enableActions(); Insets insets = c.getInsets(); int width = c.getBounds().width - insets.left - insets.right; int height = c.getBounds().height - insets.top - insets.bottom; // MenuBar is always present and located at the top left corner. Dimension menupref = menuBar.getPreferredSize(); menuBar.setBounds(insets.left, insets.top, menupref.width, height); int loc = width + insets.left; Insets i = closeButton.getInsets(); Dimension prefs = new Dimension(iconSize + i.left + i.right, iconSize + i.top + i.bottom); int top = insets.top + (height - prefs.height) / 2; if (closeAction.isEnabled()) { loc -= prefs.width; closeButton.setVisible(true); closeButton.setBounds(loc, top, prefs.width, prefs.height); } else closeButton.setVisible(false); if (maximizeAction.isEnabled()) { loc -= prefs.width; maxButton.setVisible(true); maxButton.setBounds(loc, top, prefs.width, prefs.height); } else maxButton.setVisible(false); if (iconifyAction.isEnabled()) { loc -= prefs.width; iconButton.setVisible(true); iconButton.setBounds(loc, top, prefs.width, prefs.height); } else iconButton.setVisible(false); if (title != null) title.setBounds(insets.left + menupref.width, insets.top, loc - menupref.width - insets.left, height); } /** * This method returns the minimum size of the given Container given the * children that it has. * * @param c The Container to get a minimum size for. * * @return The minimum size of the Container. */ public Dimension minimumLayoutSize(Container c) { return preferredLayoutSize(c); } /** * This method returns the preferred size of the given Container taking * into account the children that it has. * * @param c The Container to lay out. * * @return The preferred size of the Container. */ public Dimension preferredLayoutSize(Container c) { Insets frameInsets = frame.getInsets(); // Height is the max of the preferredHeights of all components // inside the pane int height = 0; int width = 0; Dimension d; Component[] components = BasicInternalFrameTitlePane.this.getComponents(); for (int i = 0; i < components.length; i++) { d = components[i].getPreferredSize(); height = Math.max(height, d.height); width += d.width; } Insets insets = BasicInternalFrameTitlePane.this.getInsets(); height += insets.top + insets.bottom; return new Dimension(width, height); } /** * This method is called when removing a Component from the Container. * * @param c The Component to remove. */ public void removeLayoutComponent(Component c) { } } /** * This helper class is used to create the minimize, maximize and close * buttons in the top right corner of the Title Pane. These buttons are * special since they cannot be given focus and have no border. */ private class PaneButton extends JButton { /** * Creates a new PaneButton object with the given Action. * * @param a The Action that the button uses. */ public PaneButton(Action a) { super(a); setMargin(new Insets(0, 0, 0, 0)); setBorder(null); } /** * This method returns true if the Component can be focused. * * @return false. */ public boolean isFocusable() { // These buttons cannot be given focus. return false; } } /** The action command for the Close action. */ protected static final String CLOSE_CMD = "Close"; /** The action command for the Minimize action. */ protected static final String ICONIFY_CMD = "Minimize"; /** The action command for the Maximize action. */ protected static final String MAXIMIZE_CMD = "Maximize"; /** The action command for the Move action. */ protected static final String MOVE_CMD = "Move"; /** The action command for the Restore action. */ protected static final String RESTORE_CMD = "Restore"; /** The action command for the Size action. */ protected static final String SIZE_CMD = "Size"; /** The action associated with closing the JInternalFrame. */ protected Action closeAction; /** The action associated with iconifying the JInternalFrame. */ protected Action iconifyAction; /** The action associated with maximizing the JInternalFrame. */ protected Action maximizeAction; /** The action associated with moving the JInternalFrame. */ protected Action moveAction; /** The action associated with restoring the JInternalFrame. */ protected Action restoreAction; /** The action associated with resizing the JInternalFrame. */ protected Action sizeAction; /** The button that closes the JInternalFrame. */ protected JButton closeButton; /** The button that iconifies the JInternalFrame. */ protected JButton iconButton; /** The button that maximizes the JInternalFrame. */ protected JButton maxButton; /** Active background color. */ protected Color activeBGColor; /** Active foreground color. */ protected Color activeFGColor; /** Inactive background color. */ protected Color inactiveBGColor; /** Inactive foreground color. */ protected Color inactiveFGColor; // FIXME: These icons need to be moved to MetalIconFactory.
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?