basicmenuitemui.java
来自「Mac OS X 10.4.9 for x86 Source Code gcc」· Java 代码 · 共 999 行 · 第 1/2 页
JAVA
999 行
/* MenuItems insets are equal to menuItems margin, space between text and menuItems border. We need to paint insets region as well. */ Insets insets = m.getInsets(); br.x -= insets.left; br.y -= insets.top; br.width += insets.right + insets.left; br.height += insets.top + insets.bottom; /* Menu item is considered to be highlighted when it is selected. It is considered to be selected if menu item is inside some menu and is armed or if it is both armed and pressed */ if (m.getModel().isArmed() && (m.getParent() instanceof MenuElement || m.getModel().isPressed())) { if (m.isContentAreaFilled()) { g.setColor(selectionBackground); g.fillRect(br.x, br.y, br.width, br.height); } } else { if (m.isContentAreaFilled()) { g.setColor(m.getBackground()); g.fillRect(br.x, br.y, br.width, br.height); } } // If this menu item is a JCheckBoxMenuItem then paint check icon if (checkIcon != null) { SwingUtilities.layoutCompoundLabel(m, fm, null, checkIcon, vertAlign, horAlign, vertTextPos, horTextPos, vr, cr, tr, defaultTextIconGap); checkIcon.paintIcon(m, g, cr.x, cr.y); // We need to calculate position of the menu text and position of // user menu icon if there exists one relative to the check icon. // So we need to adjust view rectangle s.t. its starting point is at // checkIcon.width + defaultTextIconGap. vr.x = cr.x + cr.width + defaultTextIconGap; } // if this is a submenu, then paint arrow icon to indicate it. if (arrowIcon != null && (c instanceof JMenu)) { if (! ((JMenu) c).isTopLevelMenu()) { int width = arrowIcon.getIconWidth(); int height = arrowIcon.getIconHeight(); arrowIcon.paintIcon(m, g, vr.width - width + defaultTextIconGap, vr.y + 2); } } // paint text and user menu icon if it exists Icon i = m.getIcon(); SwingUtilities.layoutCompoundLabel(c, fm, m.getText(), i, vertAlign, horAlign, vertTextPos, horTextPos, vr, ir, tr, defaultTextIconGap); if (i != null) i.paintIcon(c, g, ir.x, ir.y); paintText(g, m, tr, m.getText()); // paint accelerator String acceleratorText = ""; if (m.getAccelerator() != null) { acceleratorText = getAcceleratorText(m.getAccelerator()); fm = g.getFontMetrics(acceleratorFont); ar.width = fm.stringWidth(acceleratorText); ar.x = br.width - ar.width; vr.x = br.width - ar.width; SwingUtilities.layoutCompoundLabel(m, fm, acceleratorText, null, vertAlign, horAlign, vertTextPos, horTextPos, vr, ir, ar, defaultTextIconGap); paintAccelerator(g, m, ar, acceleratorText); } } /** * Paints label for the given menu item * * @param g The graphics context used to paint this menu item * @param menuItem menu item for which to draw its label * @param textRect rectangle specifiying position of the text relative to * the given menu item * @param text label of the menu item */ protected void paintText(Graphics g, JMenuItem menuItem, Rectangle textRect, String text) { Font f = menuItem.getFont(); g.setFont(f); FontMetrics fm = g.getFontMetrics(f); if (text != null && ! text.equals("")) { if (menuItem.isEnabled()) g.setColor(menuItem.getForeground()); else // FIXME: should fix this to use 'disabledForeground', but its // default value in BasicLookAndFeel is null. g.setColor(Color.gray); int mnemonicIndex = menuItem.getDisplayedMnemonicIndex(); if (mnemonicIndex != -1) BasicGraphicsUtils.drawStringUnderlineCharAt(g, text, mnemonicIndex, textRect.x, textRect.y + fm.getAscent()); else BasicGraphicsUtils.drawString(g, text, 0, textRect.x, textRect.y + fm.getAscent()); } } /** * This method uninstalls the components for this {@link JMenuItem}. * * @param menuItem The {@link JMenuItem} to uninstall components for. */ protected void uninstallComponents(JMenuItem menuItem) { // FIXME: need to implement } /** * This method uninstalls the defaults and sets any objects created during * install to null */ protected void uninstallDefaults() { menuItem.setForeground(null); menuItem.setBackground(null); menuItem.setBorder(null); menuItem.setMargin(null); menuItem.setBackground(null); menuItem.setBorder(null); menuItem.setFont(null); menuItem.setForeground(null); menuItem.setMargin(null); acceleratorFont = null; acceleratorForeground = null; acceleratorSelectionForeground = null; arrowIcon = null; selectionBackground = null; selectionForeground = null; acceleratorDelimiter = null; } /** * Uninstalls any keyboard actions. */ protected void uninstallKeyboardActions() { // FIXME: need to implement } /** * Unregisters all the listeners that this UI delegate was using. */ protected void uninstallListeners() { menuItem.removeMouseListener(mouseInputListener); menuItem.removeMenuDragMouseListener(menuDragMouseListener); menuItem.removeMenuKeyListener(menuKeyListener); menuItem.removePropertyChangeListener(propertyChangeListener); } /** * Performs the opposite of installUI. Any properties or resources that need * to be cleaned up will be done now. It will also uninstall any listeners * it has. In addition, any properties of this UI will be nulled. * * @param c The {@link JComponent} that is having this UI uninstalled. */ public void uninstallUI(JComponent c) { uninstallListeners(); uninstallDefaults(); uninstallComponents(menuItem); menuItem = null; } /** * This method calls paint. * * @param g The graphics context used to paint this menu item * @param c The menu item to paint */ public void update(Graphics g, JComponent c) { paint(g, c); } /** * Return text representation of the specified accelerator * * @param accelerator Accelerator for which to return string representation * * @return $String$ Text representation of the given accelerator */ private String getAcceleratorText(KeyStroke accelerator) { // convert keystroke into string format String modifiersText = ""; int modifiers = accelerator.getModifiers(); char keyChar = accelerator.getKeyChar(); int keyCode = accelerator.getKeyCode(); if (modifiers != 0) modifiersText = KeyEvent.getKeyModifiersText(modifiers) + acceleratorDelimiter; if (keyCode == KeyEvent.VK_UNDEFINED) return modifiersText + keyChar; else return modifiersText + KeyEvent.getKeyText(keyCode); } /** * Calculates and return rectange in which accelerator should be displayed * * @param accelerator accelerator for which to return the display rectangle * @param fm The font metrics used to measure the text * * @return $Rectangle$ reactangle which will be used to display accelerator */ private Rectangle getAcceleratorRect(KeyStroke accelerator, FontMetrics fm) { int width = fm.stringWidth(getAcceleratorText(accelerator)); int height = fm.getHeight(); return new Rectangle(0, 0, width, height); } /** * Paints accelerator inside menu item * * @param g The graphics context used to paint the border * @param menuItem Menu item for which to draw accelerator * @param acceleratorRect rectangle representing position * of the accelerator relative to the menu item * @param acceleratorText accelerator's text */ private void paintAccelerator(Graphics g, JMenuItem menuItem, Rectangle acceleratorRect, String acceleratorText) { g.setFont(acceleratorFont); FontMetrics fm = g.getFontMetrics(acceleratorFont); if (menuItem.isEnabled()) g.setColor(acceleratorForeground); else // FIXME: should fix this to use 'disabledForeground', but its // default value in BasicLookAndFeel is null. g.setColor(Color.gray); BasicGraphicsUtils.drawString(g, acceleratorText, 0, acceleratorRect.x, acceleratorRect.y + fm.getAscent()); } /** * This class handles mouse events occuring inside the menu item. * Most of the events are forwarded for processing to MenuSelectionManager * of the current menu hierarchy. * */ protected class MouseInputHandler implements MouseInputListener { /** * Creates a new MouseInputHandler object. */ protected MouseInputHandler() { } /** * This method is called when mouse is clicked on the menu item. * It forwards this event to MenuSelectionManager. * * @param e A {@link MouseEvent}. */ public void mouseClicked(MouseEvent e) { MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.processMouseEvent(e); } /** * This method is called when mouse is dragged inside the menu item. * It forwards this event to MenuSelectionManager. * * @param e A {@link MouseEvent}. */ public void mouseDragged(MouseEvent e) { MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.processMouseEvent(e); } /** * This method is called when mouse enters menu item. * When this happens menu item is considered to be selected and selection path * in MenuSelectionManager is set. This event is also forwarded to MenuSelection * Manager for further processing. * * @param e A {@link MouseEvent}. */ public void mouseEntered(MouseEvent e) { Component source = (Component) e.getSource(); if (source.getParent() instanceof MenuElement) { MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.setSelectedPath(getPath()); manager.processMouseEvent(e); } } /** * This method is called when mouse exits menu item. The event is * forwarded to MenuSelectionManager for processing. * * @param e A {@link MouseEvent}. */ public void mouseExited(MouseEvent e) { MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.processMouseEvent(e); } /** * This method is called when mouse is inside the menu item. * This event is forwarder to MenuSelectionManager for further processing. * * @param e A {@link MouseEvent}. */ public void mouseMoved(MouseEvent e) { MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.processMouseEvent(e); } /** * This method is called when mouse is pressed. This event is forwarded to * MenuSelectionManager for further processing. * * @param e A {@link MouseEvent}. */ public void mousePressed(MouseEvent e) { MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.processMouseEvent(e); } /** * This method is called when mouse is released. If the mouse is released * inside this menuItem, then this menu item is considered to be chosen and * the menu hierarchy should be closed. * * @param e A {@link MouseEvent}. */ public void mouseReleased(MouseEvent e) { Rectangle size = menuItem.getBounds(); MenuSelectionManager manager = MenuSelectionManager.defaultManager(); if (e.getX() > 0 && e.getX() < size.width && e.getY() > 0 && e.getY() < size.height) { manager.clearSelectedPath(); menuItem.doClick(); } else manager.processMouseEvent(e); } } /** * This class handles mouse dragged events. */ protected class MenuDragMouseHandler implements MenuDragMouseListener { /** * Tbis method is invoked when mouse is dragged over the menu item. * * @param e The MenuDragMouseEvent */ public void menuDragMouseDragged(MenuDragMouseEvent e) { MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.setSelectedPath(e.getPath()); } /** * Tbis method is invoked when mouse enters the menu item while it is * being dragged. * * @param e The MenuDragMouseEvent */ public void menuDragMouseEntered(MenuDragMouseEvent e) { MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.setSelectedPath(e.getPath()); } /** * Tbis method is invoked when mouse exits the menu item while * it is being dragged * * @param e The MenuDragMouseEvent */ public void menuDragMouseExited(MenuDragMouseEvent e) { } /** * Tbis method is invoked when mouse was dragged and released * inside the menu item. * * @param e The MenuDragMouseEvent */ public void menuDragMouseReleased(MenuDragMouseEvent e) { MenuElement[] path = e.getPath(); if (path[path.length - 1] instanceof JMenuItem) ((JMenuItem) path[path.length - 1]).doClick(); MenuSelectionManager manager = MenuSelectionManager.defaultManager(); manager.clearSelectedPath(); } } /** * This class handles key events occuring when menu item is visible on the * screen. */ protected class MenuKeyHandler implements MenuKeyListener { /** * This method is invoked when key has been pressed * * @param e A {@link MenuKeyEvent}. */ public void menuKeyPressed(MenuKeyEvent e) { } /** * This method is invoked when key has been pressed * * @param e A {@link MenuKeyEvent}. */ public void menuKeyReleased(MenuKeyEvent e) { } /** * This method is invoked when key has been typed * It handles the mnemonic key for the menu item. * * @param e A {@link MenuKeyEvent}. */ public void menuKeyTyped(MenuKeyEvent e) { } } /** * Helper class that listens for changes to the properties of the {@link * JMenuItem}. */ protected class PropertyChangeHandler implements PropertyChangeListener { /** * This method is called when one of the menu item's properties change. * * @param evt A {@link PropertyChangeEvent}. */ public void propertyChange(PropertyChangeEvent evt) { menuItem.revalidate(); menuItem.repaint(); } }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?