basicscrollpaneui.java

来自「JAVA的一些源码 JAVA2 STANDARD EDITION DEVELO」· Java 代码 · 共 948 行 · 第 1/3 页

JAVA
948
字号
/* * @(#)BasicScrollPaneUI.java	1.70 03/12/19 * * Copyright 2004 Sun Microsystems, Inc. All rights reserved. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. */package javax.swing.plaf.basic;import sun.swing.DefaultLookup;import sun.swing.UIAction;import javax.swing.*;import javax.swing.event.*;import javax.swing.border.*;import javax.swing.plaf.*;import java.beans.PropertyChangeListener;import java.beans.PropertyChangeEvent;import java.awt.Component;import java.awt.Container;import java.awt.LayoutManager;import java.awt.Rectangle;import java.awt.Dimension;import java.awt.Point;import java.awt.Insets;import java.awt.Graphics;import java.awt.event.*;import java.io.Serializable;import java.awt.Toolkit;/** * A default L&F implementation of ScrollPaneUI. * * @version 1.70 12/19/03 * @author Hans Muller */public class BasicScrollPaneUI    extends ScrollPaneUI implements ScrollPaneConstants{    protected JScrollPane scrollpane;    protected ChangeListener vsbChangeListener;    protected ChangeListener hsbChangeListener;    protected ChangeListener viewportChangeListener;    protected PropertyChangeListener spPropertyChangeListener;    private MouseWheelListener mouseScrollListener;    /**     * PropertyChangeListener installed on the vertical scrollbar.     */    private PropertyChangeListener vsbPropertyChangeListener;    /**     * PropertyChangeListener installed on the horizontal scrollbar.     */    private PropertyChangeListener hsbPropertyChangeListener;    private Handler handler;    /**     * State flag that shows whether setValue() was called from a user program     * before the value of "extent" was set in right-to-left component     * orientation.     */    private boolean setValueCalled = false;    public static ComponentUI createUI(JComponent x) {	return new BasicScrollPaneUI();    }    static void loadActionMap(LazyActionMap map) {        map.put(new Actions(Actions.SCROLL_UP));	map.put(new Actions(Actions.SCROLL_DOWN));	map.put(new Actions(Actions.SCROLL_HOME));	map.put(new Actions(Actions.SCROLL_END));	map.put(new Actions(Actions.UNIT_SCROLL_UP));	map.put(new Actions(Actions.UNIT_SCROLL_DOWN));        map.put(new Actions(Actions.SCROLL_LEFT));        map.put(new Actions(Actions.SCROLL_RIGHT));        map.put(new Actions(Actions.UNIT_SCROLL_RIGHT));        map.put(new Actions(Actions.UNIT_SCROLL_LEFT));    }    public void paint(Graphics g, JComponent c) {	Border vpBorder = scrollpane.getViewportBorder();	if (vpBorder != null) {	    Rectangle r = scrollpane.getViewportBorderBounds();	    vpBorder.paintBorder(scrollpane, g, r.x, r.y, r.width, r.height);	}    }    /**     * @return new Dimension(Short.MAX_VALUE, Short.MAX_VALUE)     */    public Dimension getMaximumSize(JComponent c) {	return new Dimension(Short.MAX_VALUE, Short.MAX_VALUE);    }    protected void installDefaults(JScrollPane scrollpane)     {	LookAndFeel.installBorder(scrollpane, "ScrollPane.border");	LookAndFeel.installColorsAndFont(scrollpane, 	    "ScrollPane.background", 	    "ScrollPane.foreground",             "ScrollPane.font");        Border vpBorder = scrollpane.getViewportBorder();        if ((vpBorder == null) ||( vpBorder instanceof UIResource)) {	    vpBorder = UIManager.getBorder("ScrollPane.viewportBorder");	    scrollpane.setViewportBorder(vpBorder);        }        LookAndFeel.installProperty(scrollpane, "opaque", Boolean.TRUE);    }    protected void installListeners(JScrollPane c)     {	vsbChangeListener = createVSBChangeListener();        vsbPropertyChangeListener = createVSBPropertyChangeListener();	hsbChangeListener = createHSBChangeListener();        hsbPropertyChangeListener = createHSBPropertyChangeListener();	viewportChangeListener = createViewportChangeListener();	spPropertyChangeListener = createPropertyChangeListener();	JViewport viewport = scrollpane.getViewport();	JScrollBar vsb = scrollpane.getVerticalScrollBar();	JScrollBar hsb = scrollpane.getHorizontalScrollBar();	if (viewport != null) {	    viewport.addChangeListener(viewportChangeListener);	}	if (vsb != null) {	    vsb.getModel().addChangeListener(vsbChangeListener);            vsb.addPropertyChangeListener(vsbPropertyChangeListener);	}	if (hsb != null) {	    hsb.getModel().addChangeListener(hsbChangeListener);            hsb.addPropertyChangeListener(hsbPropertyChangeListener);	}	scrollpane.addPropertyChangeListener(spPropertyChangeListener);    mouseScrollListener = createMouseWheelListener();    scrollpane.addMouseWheelListener(mouseScrollListener);    }    protected void installKeyboardActions(JScrollPane c) {	InputMap inputMap = getInputMap(JComponent.				  WHEN_ANCESTOR_OF_FOCUSED_COMPONENT);	SwingUtilities.replaceUIInputMap(c, JComponent.			       WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, inputMap);        LazyActionMap.installLazyActionMap(c, BasicScrollPaneUI.class,                                           "ScrollPane.actionMap");    }    InputMap getInputMap(int condition) {	if (condition == JComponent.WHEN_ANCESTOR_OF_FOCUSED_COMPONENT) {	    InputMap keyMap = (InputMap)DefaultLookup.get(scrollpane, this,                                        "ScrollPane.ancestorInputMap");	    InputMap rtlKeyMap;	    if (scrollpane.getComponentOrientation().isLeftToRight() ||		    ((rtlKeyMap = (InputMap)DefaultLookup.get(scrollpane, this,                    "ScrollPane.ancestorInputMap.RightToLeft")) == null)) {		return keyMap;	    } else {		rtlKeyMap.setParent(keyMap);		return rtlKeyMap;	    }	}	return null;    }    public void installUI(JComponent x) {	scrollpane = (JScrollPane)x;	installDefaults(scrollpane);	installListeners(scrollpane);	installKeyboardActions(scrollpane);    }    protected void uninstallDefaults(JScrollPane c) {	LookAndFeel.uninstallBorder(scrollpane);        if (scrollpane.getViewportBorder() instanceof UIResource) {            scrollpane.setViewportBorder(null);        }    }    protected void uninstallListeners(JComponent c) {	JViewport viewport = scrollpane.getViewport();	JScrollBar vsb = scrollpane.getVerticalScrollBar();	JScrollBar hsb = scrollpane.getHorizontalScrollBar();	if (viewport != null) {	    viewport.removeChangeListener(viewportChangeListener);	}	if (vsb != null) {	    vsb.getModel().removeChangeListener(vsbChangeListener);            vsb.removePropertyChangeListener(vsbPropertyChangeListener);	}	if (hsb != null) {	    hsb.getModel().removeChangeListener(hsbChangeListener);            hsb.removePropertyChangeListener(hsbPropertyChangeListener);	}	scrollpane.removePropertyChangeListener(spPropertyChangeListener);    if (mouseScrollListener != null) {        scrollpane.removeMouseWheelListener(mouseScrollListener);    }	vsbChangeListener = null;	hsbChangeListener = null;	viewportChangeListener = null;	spPropertyChangeListener = null;        mouseScrollListener = null;        handler = null;    }    protected void uninstallKeyboardActions(JScrollPane c) {	SwingUtilities.replaceUIActionMap(c, null);	SwingUtilities.replaceUIInputMap(c, JComponent.			   WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, null);    }    public void uninstallUI(JComponent c) {	uninstallDefaults(scrollpane);	uninstallListeners(scrollpane);	uninstallKeyboardActions(scrollpane);	scrollpane = null;    }    private Handler getHandler() {        if (handler == null) {            handler = new Handler();        }        return handler;    }    protected void syncScrollPaneWithViewport()    {	JViewport viewport = scrollpane.getViewport();	JScrollBar vsb = scrollpane.getVerticalScrollBar();	JScrollBar hsb = scrollpane.getHorizontalScrollBar();	JViewport rowHead = scrollpane.getRowHeader();	JViewport colHead = scrollpane.getColumnHeader();	boolean ltr = scrollpane.getComponentOrientation().isLeftToRight();	if (viewport != null) {	    Dimension extentSize = viewport.getExtentSize();	    Dimension viewSize = viewport.getViewSize();	    Point viewPosition = viewport.getViewPosition();	    if (vsb != null) {		int extent = extentSize.height;		int max = viewSize.height;		int value = Math.max(0, Math.min(viewPosition.y, max - extent));		vsb.setValues(value, extent, 0, max);	    }	    if (hsb != null) {		int extent = extentSize.width;		int max = viewSize.width;		int value;		if (ltr) {		    value = Math.max(0, Math.min(viewPosition.x, max - extent));		} else {		    int currentValue = hsb.getValue();		    /* Use a particular formula to calculate "value"		     * until effective x coordinate is calculated.		     */		    if (setValueCalled && ((max - currentValue) == viewPosition.x)) {			value = Math.max(0, Math.min(max - extent, currentValue));			/* After "extent" is set, turn setValueCalled flag off.			 */			if (extent != 0) {			    setValueCalled = false;			}		    } else {			if (extent > max) {			    viewPosition.x = max - extent;			    viewport.setViewPosition(viewPosition);			    value = 0;			} else {			   /* The following line can't handle a small value of			    * viewPosition.x like Integer.MIN_VALUE correctly			    * because (max - extent - viewPositoiin.x) causes			    * an overflow. As a result, value becomes zero.			    * (e.g. setViewPosition(Integer.MAX_VALUE, ...)			    *       in a user program causes a overflow.			    *       Its expected value is (max - extent).)			    * However, this seems a trivial bug and adding a			    * fix makes this often-called method slow, so I'll			    * leave it until someone claims.			    */			    value = Math.max(0, Math.min(max - extent, max - extent - viewPosition.x));			}		    }		}		hsb.setValues(value, extent, 0, max);	    }

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?