--- a/editor/nbproject/project.xml +++ a/editor/nbproject/project.xml @@ -151,7 +151,7 @@ - 7.7 + 7.38 --- a/editor/src/org/netbeans/modules/editor/impl/ReplaceBar.java +++ a/editor/src/org/netbeans/modules/editor/impl/ReplaceBar.java @@ -235,8 +235,6 @@ padding.setOpaque(false); add(padding); - add(createCloseButton()); - searchBarFocusTraversalPolicy = createSearchBarFocusTraversalPolicy(); setVisible(false); @@ -542,20 +540,6 @@ return incSearchComboBox; } - private JButton createCloseButton() throws MissingResourceException { - JButton closeButton = new JButton(ImageUtilities.loadImageIcon("org/netbeans/modules/editor/resources/find_close.png", false)); // NOI18N - closeButton.addActionListener(new ActionListener() { - - @Override - public void actionPerformed(ActionEvent e) { - looseFocus(); - } - }); - closeButton.setToolTipText(NbBundle.getMessage(SearchBar.class, "TOOLTIP_CloseIncrementalSearchSidebar")); // NOI18N - closeButton.setMargin(BUTTON_INSETS); - return closeButton; - } - private void addEscapeKeystrokeFocusBackTo(JPanel jpanel) { jpanel.getInputMap(JComponent.WHEN_ANCESTOR_OF_FOCUSED_COMPONENT).put(KeyStroke.getKeyStroke(KeyEvent.VK_ESCAPE, 0, true), "loose-focus"); // NOI18N @@ -595,8 +579,21 @@ } } + private ActionListener closeButtonListener; + private ActionListener getCloseButtonListener() { + if (closeButtonListener == null) + closeButtonListener = new ActionListener() { + + @Override + public void actionPerformed(ActionEvent e) { + looseFocus(); + } + }; + return closeButtonListener; + } + private void unchangeSearchBarToBeOnlySearchBar() throws MissingResourceException { - searchBar.getCloseButton().setVisible(true); + searchBar.getCloseButton().removeActionListener(getCloseButtonListener()); Mnemonics.setLocalizedText(searchBar.getFindLabel(), NbBundle.getMessage(SearchBar.class, "CTL_Find")); // NOI18N searchBar.getFindLabel().setPreferredSize(searchBar.getFindLabel().getMinimumSize()); searchBar.addEscapeKeystrokeFocusBackTo(searchBar); @@ -610,7 +607,7 @@ } private void changeSearchBarToBePartOfReplaceBar() throws MissingResourceException { - searchBar.getCloseButton().setVisible(false); + searchBar.getCloseButton().addActionListener(getCloseButtonListener()); Mnemonics.setLocalizedText(searchBar.getFindLabel(), NbBundle.getMessage(SearchBar.class, "CTL_Replace_Find")); // NOI18N searchBar.getFindLabel().setPreferredSize(new Dimension(replaceLabel.getPreferredSize().width, searchBar.getFindLabel().getPreferredSize().height)); this.addEscapeKeystrokeFocusBackTo(searchBar); --- a/editor/src/org/netbeans/modules/editor/impl/SearchBar.java +++ a/editor/src/org/netbeans/modules/editor/impl/SearchBar.java @@ -102,6 +102,7 @@ import javax.swing.text.Keymap; import org.netbeans.api.editor.EditorRegistry; import org.netbeans.modules.editor.lib2.search.EditorFindSupport; +import org.openide.awt.CloseButtonFactory; import org.openide.awt.Mnemonics; import org.openide.awt.StatusDisplayer; import org.openide.filesystems.FileObject; @@ -467,7 +468,7 @@ } private JButton createCloseButton() throws MissingResourceException { - JButton button = new JButton(ImageUtilities.loadImageIcon("org/netbeans/modules/editor/resources/find_close.png", false)); // NOI18N + JButton button = CloseButtonFactory.createBigCloseButton(); button.addActionListener(new ActionListener() { @Override @@ -476,7 +477,6 @@ } }); button.setToolTipText(NbBundle.getMessage(SearchBar.class, "TOOLTIP_CloseIncrementalSearchSidebar")); // NOI18N - button.setMargin(BUTTON_INSETS); return button; } @@ -686,7 +686,7 @@ int parentWidth = this.getParent().getWidth(); int totalWidth = 0; for (Component c : this.getComponents()) { - if (c != padding && (c != closeButton || c.isVisible())) { + if (c != padding) { totalWidth += c.getPreferredSize().width; } } --- a/openide.awt/apichanges.xml +++ a/openide.awt/apichanges.xml @@ -50,6 +50,21 @@ AWT API + + + Close Button API + + + + + +

+ New close button factory to a create close button or a big close button. +

+
+ + +
Turn on Mnemonics in Popup Menus --- a/openide.awt/manifest.mf +++ a/openide.awt/manifest.mf @@ -2,5 +2,5 @@ OpenIDE-Module: org.openide.awt OpenIDE-Module-Localizing-Bundle: org/openide/awt/Bundle.properties AutoUpdate-Essential-Module: true -OpenIDE-Module-Specification-Version: 7.37 +OpenIDE-Module-Specification-Version: 7.38 --- a/openide.awt/src/org/openide/awt/CloseButtonFactory.java +++ a/openide.awt/src/org/openide/awt/CloseButtonFactory.java @@ -0,0 +1,252 @@ +/* + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. + * + * Copyright 1997-2010 Oracle and/or its affiliates. All rights reserved. + * + * Oracle and Java are registered trademarks of Oracle and/or its affiliates. + * Other names may be trademarks of their respective owners. + * + * The contents of this file are subject to the terms of either the GNU + * General Public License Version 2 only ("GPL") or the Common + * Development and Distribution License("CDDL") (collectively, the + * "License"). You may not use this file except in compliance with the + * License. You can obtain a copy of the License at + * http://www.netbeans.org/cddl-gplv2.html + * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the + * specific language governing permissions and limitations under the + * License. When distributing the software, include this License Header + * Notice in each file and include the License file at + * nbbuild/licenses/CDDL-GPL-2-CP. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the GPL Version 2 section of the License file that + * accompanied this code. If applicable, add the following below the + * License Header, with the fields enclosed by brackets [] replaced by + * your own identifying information: + * "Portions Copyrighted [year] [name of copyright owner]" + * + * Contributor(s): + * + * The Original Software is NetBeans. The Initial Developer of the Original + * Software is Sun Microsystems, Inc. Portions Copyright 1997-2007 Sun + * Microsystems, Inc. All Rights Reserved. + * + * If you wish your version of this file to be governed by only the CDDL + * or only the GPL Version 2, indicate your decision by adding + * "[Contributor] elects to include this software in this distribution + * under the [CDDL or GPL Version 2] license." If you do not indicate a + * single choice of license, a recipient has the option to distribute + * your version of this file under either the CDDL, the GPL Version 2 or + * to extend the choice of license to its licensees as provided above. + * However, if you add GPL Version 2 code and therefore, elected the GPL + * Version 2 license, then the option applies only if the new code is + * made subject to such option by the copyright holder. + */ + +package org.openide.awt; + +import java.awt.Dimension; +import java.awt.Image; +import java.awt.Toolkit; +import javax.swing.BorderFactory; +import javax.swing.JButton; +import javax.swing.UIManager; +import org.openide.util.ImageUtilities; + +/** + * Factory class for Close Buttons. + * + * @author M. Kristofic + * @since 7.38 + */ +public final class CloseButtonFactory{ + + private static Image closeTabImage; + private static Image closeTabPressedImage; + private static Image closeTabMouseOverImage; + private static Image bigCloseTabImage; + private static Image bigCloseTabPressedImage; + private static Image bigCloseTabMouseOverImage; + + private CloseButtonFactory() { + } + + /** + * Creates a small 'close' JButton with close icon, rollover icon and pressed icon according to Look and Feel + * + * @return JButton with close icons. + */ + public static JButton createCloseButton() { + JButton closeButton = new JButton(); + int size = 16; + closeButton.setPreferredSize(new Dimension(size, size)); + closeButton.setContentAreaFilled(false); + closeButton.setFocusable(false); + closeButton.setBorder(BorderFactory.createEmptyBorder()); + closeButton.setBorderPainted(false); + closeButton.setRolloverEnabled(true); + closeButton.setIcon(ImageUtilities.image2Icon(getCloseTabImage())); + closeButton.setRolloverIcon(ImageUtilities.image2Icon(getCloseTabRolloverImage())); + closeButton.setPressedIcon(ImageUtilities.image2Icon(getCloseTabPressedImage())); + return closeButton; + } + + /** + * Creates a big 'close' JButton with close icon, rollover icon and pressed icon according to Look and Feel + * + * @return JButton with close icons. + */ + public static JButton createBigCloseButton() { + JButton closeButton = new JButton(); + int size = 19; + closeButton.setPreferredSize(new Dimension(size, size)); + closeButton.setContentAreaFilled(false); + closeButton.setFocusable(false); + closeButton.setBorder(BorderFactory.createEmptyBorder()); + closeButton.setBorderPainted(false); + closeButton.setRolloverEnabled(true); + closeButton.setIcon(ImageUtilities.image2Icon(getBigCloseTabImage())); + closeButton.setRolloverIcon(ImageUtilities.image2Icon(getBigCloseTabRolloverImage())); + closeButton.setPressedIcon(ImageUtilities.image2Icon(getBigCloseTabPressedImage())); + return closeButton; + } + + private static boolean isWindowsVistaLaF() { + String osName = System.getProperty("os.name"); + return osName.indexOf("Vista") >= 0 + || (osName.equals("Windows NT (unknown)") && "6.0".equals(System.getProperty("os.version"))); + } + + private static boolean isWindowsXPLaF() { + Boolean isXP = (Boolean) Toolkit.getDefaultToolkit(). + getDesktopProperty("win.xpstyle.themeActive"); //NOI18N + return isWindowsLaF() && (isXP == null ? false : isXP.booleanValue()); + } + + private static boolean isWindowsLaF() { + String lfID = UIManager.getLookAndFeel().getID(); + return lfID.endsWith("Windows"); //NOI18N + } + + private static boolean isAquaLaF() { + return "Aqua".equals(UIManager.getLookAndFeel().getID()); + } + + private static boolean isGTKLaF () { + return "GTK".equals( UIManager.getLookAndFeel().getID() ); //NOI18N + } + + private static Image getCloseTabImage() { + if( null == closeTabImage ) { + if( isWindowsVistaLaF() ) { + closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_close_enabled.png"); // NOI18N + } else if( isWindowsXPLaF() ) { + closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_close_enabled.png"); // NOI18N + } else if( isWindowsLaF() ) { + closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/win_close_enabled.png"); // NOI18N + } else if( isAquaLaF() ) { + closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_close_enabled.png"); // NOI18N + } else if( isGTKLaF() ) { + closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/gtk_close_enabled.png"); // NOI18N + } else { + closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_close_enabled.png"); // NOI18N + } + } + return closeTabImage; + } + + private static Image getCloseTabPressedImage() { + if( null == closeTabPressedImage ) { + if( isWindowsVistaLaF() ) { + closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_close_pressed.png"); // NOI18N + } else if( isWindowsXPLaF() ) { + closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_close_pressed.png"); // NOI18N + } else if( isWindowsLaF() ) { + closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/win_close_pressed.png"); // NOI18N + } else if( isAquaLaF() ) { + closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_close_pressed.png"); // NOI18N + } else if( isGTKLaF() ) { + closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/gtk_close_pressed.png"); // NOI18N + } else { + closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_close_pressed.png"); // NOI18N + } + } + return closeTabPressedImage; + } + + private static Image getCloseTabRolloverImage() { + if( null == closeTabMouseOverImage ) { + if( isWindowsVistaLaF() ) { + closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_close_rollover.png"); // NOI18N + } else if( isWindowsXPLaF() ) { + closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_close_rollover.png"); // NOI18N + } else if( isWindowsLaF() ) { + closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/win_close_rollover.png"); // NOI18N + } else if( isAquaLaF() ) { + closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_close_rollover.png"); // NOI18N + } else if( isGTKLaF() ) { + closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/gtk_close_rollover.png"); // NOI18N + } else { + closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_close_rollover.png"); // NOI18N + } + } + return closeTabMouseOverImage; + } + + + private static Image getBigCloseTabImage() { + if( null == bigCloseTabImage ) { + if( isWindowsVistaLaF() ) { + bigCloseTabImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_bigclose_enabled.png"); // NOI18N + } else if( isWindowsXPLaF() ) { + bigCloseTabImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_bigclose_enabled.png"); // NOI18N + } else if( isWindowsLaF() ) { + bigCloseTabImage = ImageUtilities.loadImage("org/openide/awt/resources/win_bigclose_enabled.png"); // NOI18N + } else if( isAquaLaF() ) { + bigCloseTabImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_bigclose_enabled.png"); // NOI18N + } else if( isGTKLaF() ) { + bigCloseTabImage = ImageUtilities.loadImage("org/openide/awt/resources/gtk_bigclose_enabled.png"); // NOI18N + } else { + bigCloseTabImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_bigclose_enabled.png"); // NOI18N + } + } + return bigCloseTabImage; + } + + private static Image getBigCloseTabPressedImage() { + if( null == bigCloseTabPressedImage ) { + if( isWindowsVistaLaF() ) { + bigCloseTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_bigclose_pressed.png"); // NOI18N + } else if( isWindowsXPLaF() ) { + bigCloseTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_bigclose_pressed.png"); // NOI18N + } else if( isWindowsLaF() ) { + bigCloseTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/win_bigclose_pressed.png"); // NOI18N + } else if( isAquaLaF() ) { + bigCloseTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_bigclose_pressed.png"); // NOI18N + } else if( isGTKLaF() ) { + bigCloseTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/gtk_bigclose_pressed.png"); // NOI18N + } else { + bigCloseTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_bigclose_pressed.png"); // NOI18N + } + } + return bigCloseTabPressedImage; + } + + private static Image getBigCloseTabRolloverImage() { + if( null == bigCloseTabMouseOverImage ) { + if( isWindowsVistaLaF() ) { + bigCloseTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_bigclose_rollover.png"); // NOI18N + } else if( isWindowsXPLaF() ) { + bigCloseTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_bigclose_rollover.png"); // NOI18N + } else if( isWindowsLaF() ) { + bigCloseTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/win_bigclose_rollover.png"); // NOI18N + } else if( isAquaLaF() ) { + bigCloseTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_bigclose_rollover.png"); // NOI18N + } else if( isGTKLaF() ) { + bigCloseTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/gtk_bigclose_rollover.png"); // NOI18N + } else { + bigCloseTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_bigclose_rollover.png"); // NOI18N + } + } + return bigCloseTabMouseOverImage; + } +} --- a/openide.awt/src/org/openide/awt/CloseButtonTabbedPane.java +++ a/openide.awt/src/org/openide/awt/CloseButtonTabbedPane.java @@ -320,57 +320,6 @@ return "GTK".equals( UIManager.getLookAndFeel().getID() ); //NOI18N } - private Image getCloseTabImage() { - if( null == closeTabImage ) { - if( isWindowsVistaLaF() ) { - closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_close_enabled.png"); // NOI18N - } else if( isWindowsXPLaF() ) { - closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_close_enabled.png"); // NOI18N - } else if( isWindowsLaF() ) { - closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/win_close_enabled.png"); // NOI18N - } else if( isAquaLaF() ) { - closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_close_enabled.png"); // NOI18N - } else { - closeTabImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_close_enabled.png"); // NOI18N - } - } - return closeTabImage; - } - - private Image getCloseTabPressedImage() { - if( null == closeTabPressedImage ) { - if( isWindowsVistaLaF() ) { - closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_close_pressed.png"); // NOI18N - } else if( isWindowsXPLaF() ) { - closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_close_pressed.png"); // NOI18N - } else if( isWindowsLaF() ) { - closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/win_close_pressed.png"); // NOI18N - } else if( isAquaLaF() ) { - closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_close_pressed.png"); // NOI18N - } else { - closeTabPressedImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_close_pressed.png"); // NOI18N - } - } - return closeTabPressedImage; - } - - private Image getCloseTabRolloverImage() { - if( null == closeTabMouseOverImage ) { - if( isWindowsVistaLaF() ) { - closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/vista_close_rollover.png"); // NOI18N - } else if( isWindowsXPLaF() ) { - closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/xp_close_rollover.png"); // NOI18N - } else if( isWindowsLaF() ) { - closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/win_close_rollover.png"); // NOI18N - } else if( isAquaLaF() ) { - closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/mac_close_rollover.png"); // NOI18N - } else { - closeTabMouseOverImage = ImageUtilities.loadImage("org/openide/awt/resources/metal_close_rollover.png"); // NOI18N - } - } - return closeTabMouseOverImage; - } - private void setPressedCloseButtonIndex(int index) { if (pressedCloseButtonIndex == index) return; @@ -564,30 +513,18 @@ } }; add(label); - add(new TabButton()); - } + JButton tabCloseButton = CloseButtonFactory.createCloseButton(); + tabCloseButton.addActionListener(new ActionListener() { - private class TabButton extends JButton implements ActionListener { - public TabButton() { - int size = 16; - setPreferredSize(new Dimension(size, size)); - setContentAreaFilled(false); - setFocusable(false); - setBorder(BorderFactory.createEmptyBorder()); - setBorderPainted(false); - setRolloverEnabled(true); - addActionListener(this); - setIcon(ImageUtilities.image2Icon(getCloseTabImage())); - setRolloverIcon(ImageUtilities.image2Icon(getCloseTabRolloverImage())); - setPressedIcon(ImageUtilities.image2Icon(getCloseTabPressedImage())); - } - - public void actionPerformed(ActionEvent e) { - int i = indexOfTabComponent(ButtonTab.this); - if (i != -1) { - fireCloseRequest(CloseButtonTabbedPane.this.getComponentAt(i)); + @Override + public void actionPerformed(ActionEvent e) { + int i = indexOfTabComponent(ButtonTab.this); + if (i != -1) { + fireCloseRequest(CloseButtonTabbedPane.this.getComponentAt(i)); + } } - } + }); + add(tabCloseButton); } }