2 * Copyright (C) 2004, 2006 Apple Computer, Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 #include "ScrollTypes.h"
34 class GraphicsContext;
37 class PlatformMouseEvent;
39 // These match the numbers we use over in WebKit (WebFrameView.m).
43 enum ScrollbarControlSize { RegularScrollbar, SmallScrollbar, MiniScrollbar };
45 class ScrollbarClient {
47 virtual ~ScrollbarClient() {}
48 virtual void valueChanged(Scrollbar*) = 0;
50 // Used to obtain a window clip rect.
51 virtual IntRect windowClipRect() const = 0;
54 class Scrollbar : public Shared<Scrollbar> {
56 Scrollbar(ScrollbarClient*, ScrollbarOrientation, ScrollbarControlSize);
59 virtual ~Scrollbar() {}
61 virtual bool isWidget() const = 0;
63 ScrollbarOrientation orientation() const { return m_orientation; }
64 int value() const { return lroundf(m_currentPos); }
66 ScrollbarControlSize controlSize() const { return m_controlSize; }
68 void setSteps(int lineStep, int pageStep, int pixelsPerStep = 1);
71 void setProportion(int visibleSize, int totalSize);
73 bool scroll(ScrollDirection, ScrollGranularity, float multiplier = 1.0);
75 virtual int width() const = 0;
76 virtual int height() const = 0;
77 virtual void setRect(const IntRect&) = 0;
78 virtual void setEnabled(bool) = 0;
79 virtual void paint(GraphicsContext*, const IntRect& damageRect) = 0;
81 static bool hasPlatformScrollbars() {
82 // To use the platform's built-in scrollbars by default, return true. We may
83 // support styled engine scrollbars someday, and some platforms may wish to not
84 // implement a platform scrollbar at all by default. That's what this method is for.
88 // These methods are used for platform scrollbars to give :hover feedback. They will not get called
89 // when the mouse went down in a scrollbar, since it is assumed the scrollbar will start
90 // grabbing all events in that case anyway.
91 virtual bool handleMouseMoveEvent(const PlatformMouseEvent&) { return false; }
92 virtual bool handleMouseOutEvent(const PlatformMouseEvent&) { return false; }
95 virtual void updateThumbPosition() = 0;
96 virtual void updateThumbProportion() = 0;
98 ScrollbarClient* client() const { return m_client; }
100 ScrollbarClient* m_client;
101 ScrollbarOrientation m_orientation;
102 ScrollbarControlSize m_controlSize;