All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jidesoft.swing.MarqueePane Maven / Gradle / Ivy

/*
 * @(#)MarqueePane.java 6/9/2009
 *
 * Copyright 2002 - 2009 JIDE Software Inc. All rights reserved.
 *
 */

package com.jidesoft.swing;

import javax.swing.*;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;

/**
 * MarqueePane is a subclass of JScrollPane with automation of scrolling. In
 * MarqueePane, you can define the direction you want the component inside the MarqueePane to
 * scroll to and the scrolling speed.
 */
public class MarqueePane extends JScrollPane {
    private int _scrollDelay = 100;
    private int _stayDelay = 2000;
    private int _scrollAmount = 2;
    private int _scrollDirection = SCROLL_DIRECTION_LEFT;
    private int _stayPosition = -1;

    private Timer _scrollTimer = null;
    private int _scrollTimes;
    private boolean _reachStayPosition = false;

    public static final int SCROLL_DIRECTION_LEFT = 0;
    public static final int SCROLL_DIRECTION_RIGHT = 1;
    public static final int SCROLL_DIRECTION_UP = 2;
    public static final int SCROLL_DIRECTION_DOWN = 3;

    public MarqueePane(Component view) {
        super(view);
        startAutoScrolling();
    }

    public MarqueePane() {
        super();
        startAutoScrolling();
    }

    @Override
    public void updateUI() {
        super.updateUI();
        setViewportBorder(BorderFactory.createEmptyBorder(0, 0, 0, 0));
        setBorder(BorderFactory.createEmptyBorder(0, 0, 0, 0));
        setVerticalScrollBarPolicy(VERTICAL_SCROLLBAR_NEVER);
        setHorizontalScrollBarPolicy(HORIZONTAL_SCROLLBAR_NEVER);
        setWheelScrollingEnabled(false);
    }

    /**
     * Get the scroll frequency which indicating how frequent the Marquee will get repaint.
     * 

* The default value is 100ms. * * @return the scroll frequency. */ public int getScrollDelay() { return _scrollDelay; } /** * Set the scroll frequency which indicating how frequent the Marquee will get repaint. * * @param scrollDelay the scroll frequency */ public void setScrollDelay(int scrollDelay) { _scrollDelay = scrollDelay; } /** * Get the scroll amount between two repaints. *

* The default value is 2. * * @return the step size. */ public int getScrollAmount() { return _scrollAmount; } /** * Set the scroll amount between two repaints. * * @param scrollAmount the step size */ public void setScrollAmount(int scrollAmount) { _scrollAmount = scrollAmount; } /** * Get the scroll direction. *

* The value could be SCROLL_LEFT, SCROLL_RIGHT, SCROLL_UP, * SCROLL_DOWN *

* The default value is SCROLL_LEFT. * * @return the scroll direction. */ public int getScrollDirection() { return _scrollDirection; } /** * set the scroll direction. * * @param scrollDirection the scroll direction */ public void setScrollDirection(int scrollDirection) { _scrollDirection = scrollDirection; } /** * Gets delay time when it reaches a stay position. *

* The default value is 500ms. * * @return the delay time when it reaches a stay position.. */ public int getStayDelay() { return _stayDelay; } /** * Sets stay delay time when it reaches a stay position. * * @param stayDelay the delay time when it reaches a stay position. */ public void setStayDelay(int stayDelay) { _stayDelay = stayDelay; } /** * Stop auto scrolling. The view will stay where it is. */ public void stopAutoScrolling() { if (_scrollTimer != null) { if (_scrollTimer.isRunning()) { _scrollTimer.stop(); } _scrollTimer = null; } } /** * Start auto scrolling. */ public void startAutoScrolling() { stopAutoScrolling(); _scrollTimer = new Timer(getScrollDelay(), new ActionListener() { public void actionPerformed(ActionEvent e) { BoundedRangeModel rangeModel; if (getScrollDirection() == SCROLL_DIRECTION_LEFT || getScrollDirection() == SCROLL_DIRECTION_RIGHT) { rangeModel = getHorizontalScrollBar().getModel(); } else { rangeModel = getVerticalScrollBar().getModel(); } int value = rangeModel.getValue(); if (getScrollDirection() == SCROLL_DIRECTION_LEFT || getScrollDirection() == SCROLL_DIRECTION_UP) { if (value + rangeModel.getExtent() == rangeModel.getMaximum()) { rangeModel.setValue(rangeModel.getMinimum()); _scrollTimes = 0; } else if (value + getScrollAmount() + rangeModel.getExtent() > rangeModel.getMaximum()) { rangeModel.setValue(rangeModel.getMaximum() - rangeModel.getExtent()); } else { rangeModel.setValue(value + getScrollAmount()); _scrollTimes ++; } _reachStayPosition = rangeModel.getValue() == rangeModel.getMinimum(); } else { if (value == rangeModel.getMinimum()) { int maximum = rangeModel.getMaximum(); int extent = rangeModel.getExtent(); rangeModel.setValue(rangeModel.getMaximum() - rangeModel.getExtent()); // In the very beginning, range model need to be reset so we need adjust the value with it. if (maximum != rangeModel.getMaximum() || extent != rangeModel.getExtent()) { rangeModel.setValue(rangeModel.getMaximum() - rangeModel.getExtent()); } _scrollTimes = 0; } else if (value - getScrollAmount() < rangeModel.getMinimum()) { rangeModel.setValue(rangeModel.getMinimum()); } else { rangeModel.setValue(value - getScrollAmount()); _scrollTimes ++; } _reachStayPosition = rangeModel.getValue() == rangeModel.getMinimum() || rangeModel.getValue() == rangeModel.getMaximum(); } if (!_reachStayPosition && getStayPosition() >= 0) { if (_scrollTimes % getStayPosition() == 0) { _reachStayPosition = true; } } if (_scrollTimer != null) { _scrollTimer.setDelay(_reachStayPosition ? getStayDelay() : getScrollDelay()); } } }); _scrollTimer.start(); } /** * Get stay position. *

* With this field, you can let the scrolling stop for getStayTime after scrolling getStayPosition times. *

* The default value is -1, which means no stay position in the middle. * * @return the stay position. */ public int getStayPosition() { return _stayPosition; } /** * Set stay position. * * @param stayPosition the stay position */ public void setStayPosition(int stayPosition) { _stayPosition = stayPosition; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy