blob: 51b42b83ce33026284a72ba0646c8ff9ed634675 [file] [log] [blame]
/*
* 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.netbeans.core.multitabs;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.FocusEvent;
import java.awt.event.MouseEvent;
import javax.swing.Action;
import javax.swing.Icon;
import javax.swing.JButton;
import javax.swing.Timer;
import javax.swing.UIManager;
import org.netbeans.core.multitabs.impl.TabListPopupAction;
import org.netbeans.swing.tabcontrol.TabbedContainer;
import org.netbeans.swing.tabcontrol.event.TabActionEvent;
import org.openide.util.ImageUtilities;
import org.openide.util.NbBundle;
/**
* Factory that create buttons to be displayed next to document tabs. The buttons
* can maximize document window, show drop-down list of documents, scroll the documents left or right.
*
* @author S. Aubrecht
*/
public final class ButtonFactory {
/**
* Creates button to show drop-down list of documents from the given tab displayer.
* @param controller Tab displayer's controller.
* @return Drop-down list button.
*/
public static JButton createDropDownButton( Controller controller ) {
final JButton btn = new JButton( new TabListPopupAction(controller) );
Icon icon = UIManager.getIcon("nb.multitabs.button.dropdown.icon");
if (icon == null) {
icon = ImageUtilities.loadImageIcon( "org/netbeans/core/multitabs/resources/down.png", true ); //NOI18N
}
btn.setIcon( icon );
btn.setActionCommand( "pressed"); //NOI18N
btn.setFocusable( false );
btn.setToolTipText( NbBundle.getMessage(ButtonFactory.class, "Hint_DocumentList") );
return btn;
}
/**
* Creates button to maximize currently selected document in the given tab displayer.
* @param controller Tab displayer's controller.
* @return Button to maximize selected document tab.
*/
public static JButton createMaximizeButton( final Controller controller ) {
final JButton btn = new JButton();
Icon icon = UIManager.getIcon("nb.multitabs.button.maximize.icon");
if (icon == null) {
icon = ImageUtilities.loadImageIcon( "org/netbeans/core/multitabs/resources/maximize.png", true ); //NOI18N
}
btn.setIcon( icon );
btn.setToolTipText( NbBundle.getMessage(ButtonFactory.class, "Hint_MaximizeRestore") );
btn.addActionListener( new ActionListener() {
@Override
public void actionPerformed( ActionEvent e ) {
controller.postActionEvent( new TabActionEvent( btn, TabbedContainer.COMMAND_MAXIMIZE, -1 ) );
}
});
btn.setFocusable( false );
return btn;
}
/**
* Button to scroll tabs left/up. The button sets up a timer when pressed
* to call the scroll action repeatedly until released or until the action
* becomes disabled.
* @param scrollAction Action implementing the actual scrolling.
* @return Button to scroll left/up.
*/
public static JButton createScrollLeftButton( Action scrollAction ) {
JButton btn = new TimerButton( scrollAction );
Icon icon = UIManager.getIcon("nb.multitabs.button.left.icon");
if (icon == null) {
icon = ImageUtilities.loadImageIcon( "org/netbeans/core/multitabs/resources/left.png", true ); //NOI18N
}
btn.setIcon( icon );
btn.setToolTipText( NbBundle.getMessage(ButtonFactory.class, "Hint_ScrollLeft") );
return btn;
}
/**
* Button to scroll tabs right/down. The button sets up a timer when pressed
* to call the scroll action repeatedly until released or until the action
* becomes disabled.
* @param scrollAction Action implementing the actual scrolling.
* @return Button to scroll right/down.
*/
public static JButton createScrollRightButton( Action scrollAction ) {
JButton btn = new TimerButton( scrollAction );
Icon icon = UIManager.getIcon("nb.multitabs.button.right.icon");
if (icon == null) {
icon = ImageUtilities.loadImageIcon( "org/netbeans/core/multitabs/resources/right.png", true ); //NOI18N
}
btn.setIcon( icon );
btn.setToolTipText( NbBundle.getMessage(ButtonFactory.class, "Hint_ScrollRight") );
return btn;
}
/**
* A convenience button class which will continue re-firing its action
* on a timer for as long as the button is depressed. Used for left-right scroll
* buttons.
*/
private static class TimerButton extends JButton implements ActionListener {
Timer timer = null;
public TimerButton( Action a ) {
setAction( a );
setFocusable( false );
}
private Timer getTimer() {
if (timer == null) {
timer = new Timer(400, this);
timer.setRepeats(true);
}
return timer;
}
int count = 0;
@Override
public void actionPerformed( ActionEvent e ) {
count++;
if (count > 2) {
if (count > 5) {
timer.setDelay(75);
} else {
timer.setDelay(200);
}
}
performAction();
}
private void performAction() {
if (!isEnabled()) {
stopTimer();
return;
}
getAction().actionPerformed(new ActionEvent(this,
ActionEvent.ACTION_PERFORMED,
getActionCommand()));
}
private void startTimer() {
Timer t = getTimer();
if (t.isRunning()) {
return;
}
repaint();
t.setDelay(400);
t.start();
}
private void stopTimer() {
if (timer != null) {
timer.stop();
}
repaint();
count = 0;
}
@Override
protected void processMouseEvent(MouseEvent me) {
if (isEnabled() && me.getID() == MouseEvent.MOUSE_PRESSED) {
startTimer();
} else if (me.getID() == MouseEvent.MOUSE_RELEASED) {
stopTimer();
}
super.processMouseEvent(me);
}
@Override
protected void processFocusEvent(FocusEvent fe) {
super.processFocusEvent(fe);
if (fe.getID() == FocusEvent.FOCUS_LOST) {
stopTimer();
}
}
}
}