/usr/include/MYGUI/MyGUI_ScrollBar.h is in libmygui-dev 3.2.2-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 | /*
* This source file is part of MyGUI. For the latest info, see http://mygui.info/
* Distributed under the MIT License
* (See accompanying file COPYING.MIT or copy at http://opensource.org/licenses/MIT)
*/
#ifndef MYGUI_SCROLL_BAR_H_
#define MYGUI_SCROLL_BAR_H_
#include "MyGUI_Prerequest.h"
#include "MyGUI_Widget.h"
namespace MyGUI
{
class ControllerItem;
typedef delegates::CMultiDelegate2<ScrollBar*, size_t> EventHandle_ScrollBarPtrSizeT;
/** \brief @wpage{ScrollBar}
ScrollBar widget description should be here.
*/
class MYGUI_EXPORT ScrollBar :
public Widget,
public MemberObsolete<ScrollBar>
{
MYGUI_RTTI_DERIVED( ScrollBar )
public:
ScrollBar();
/** Set vertical alignment grid mode */
void setVerticalAlignment(bool _value);
/** Get vertical alignment grid mode flag */
bool getVerticalAlignment() const;
/** Set scroll range */
void setScrollRange(size_t _value);
/** Get scroll range */
size_t getScrollRange() const;
/** Set scroll position (value from 0 to range - 1) */
void setScrollPosition(size_t _value);
/** Get scroll position (value from 0 to range - 1) */
size_t getScrollPosition() const;
/** Set scroll page
@param _value Tracker step when buttons pressed
*/
void setScrollPage(size_t _value);
/** Get scroll page */
size_t getScrollPage() const;
/** Set scroll view page
@param _value Tracker step when pressed on scroll line
*/
void setScrollViewPage(size_t _value);
/** Get scroll view page */
size_t getScrollViewPage() const;
/** Set scroll view page
@param _value Tracker step when mouse wheel scrolled
*/
void setScrollWheelPage(size_t _value);
/** Get scroll view page */
size_t getScrollWheelPage() const;
/** Get size in pixels of area where scroll moves */
int getLineSize() const;
/** Set size of track in pixels
@param _value in pixels, if less than MinTrackSize, MinTrackSize used
*/
void setTrackSize(int _value);
/** Get size of track in pixels */
int getTrackSize() const;
/** Set minimal track size (used for setTrackSize)*/
void setMinTrackSize(int _value);
/** Get minimal track size */
int getMinTrackSize() const;
/** Enable or disable move to click mode.\n
Move to click mode: Tracker moves to cursor when pressed on scroll line.\n
Disabled (false) by default.
*/
void setMoveToClick(bool _value);
/** Get move to click mode flag */
bool getMoveToClick() const;
/** Set whether clicks on scrollbar buttons should be repeated at set intervals
as long as the mouse button is pressed down. Enabled (true) by default.
*/
void setRepeatEnabled(bool enabled);
/** Get whether Repeat mode is enabled
@see setRepeatEnabled
*/
bool getRepeatEnabled() const;
/** Set time that buttons need to be pressed down to start repeating. */
void setRepeatTriggerTime(float time);
/** Get time that buttons need to be pressed down to start repeating. */
float getRepeatTriggerTime(float time) const;
/** Set how much time between scrollbar button repeats. */
void setRepeatStepTime(float time);
/** Get how much time between scrollbar button repeats. */
float getRepeatStepTime(float time) const;
//! @copydoc Widget::setPosition(const IntPoint& _value)
virtual void setPosition(const IntPoint& _value);
//! @copydoc Widget::setSize(const IntSize& _value)
virtual void setSize(const IntSize& _value);
//! @copydoc Widget::setCoord(const IntCoord& _value)
virtual void setCoord(const IntCoord& _value);
/** @copydoc Widget::setPosition(int _left, int _top) */
void setPosition(int _left, int _top);
/** @copydoc Widget::setSize(int _width, int _height) */
void setSize(int _width, int _height);
/** @copydoc Widget::setCoord(int _left, int _top, int _width, int _height) */
void setCoord(int _left, int _top, int _width, int _height);
/*events:*/
/** Event : scroll tracker position changed.\n
signature : void method(MyGUI::ScrollBar* _sender, size_t _position)\n
@param _sender widget that called this event
@param _position - new tracker position
*/
EventHandle_ScrollBarPtrSizeT eventScrollChangePosition;
protected:
virtual void initialiseOverride();
virtual void shutdownOverride();
void updateTrack();
void TrackMove(int _left, int _top);
virtual void onMouseWheel(int _rel);
void notifyMousePressed(Widget* _sender, int _left, int _top, MouseButton _id);
void notifyMouseReleased(Widget* _sender, int _left, int _top, MouseButton _id);
void notifyMouseDrag(Widget* _sender, int _left, int _top, MouseButton _id);
void notifyMouseWheel(Widget* _sender, int _rel);
virtual void setPropertyOverride(const std::string& _key, const std::string& _value);
int getTrackPlaceLength() const;
private:
void repeatClick(MyGUI::Widget* _widget, MyGUI::ControllerItem* _controller);
void widgetStartPressed();
void widgetEndPressed();
void widgetFirstPartPressed();
void widgetSecondPartPressed();
protected:
// наши кнопки
Button* mWidgetStart;
Button* mWidgetEnd;
Button* mWidgetTrack;
// куски между кнопками
Widget* mWidgetFirstPart;
Widget* mWidgetSecondPart;
// смещение внутри окна
IntPoint mPreActionOffset;
// диапазон на который трек может двигаться
size_t mSkinRangeStart;
size_t mSkinRangeEnd;
size_t mScrollRange;
size_t mScrollPosition;
size_t mScrollPage; // track step, when clicking buttons
size_t mScrollViewPage; // track step, when clicking scroll line
size_t mScrollWheelPage; // track step, when scrolling with mouse wheel
bool mEnableRepeat; // Repeat clicks on the scrollbar buttons when the mouse button remains pressed down
float mRepeatTriggerTime; // Time the mouse button needs to be held for repeating to start
float mRepeatStepTime; // Time between repeats
int mMinTrackSize;
bool mMoveToClick;
bool mVerticalAlignment;
};
} // namespace MyGUI
#endif // MYGUI_SCROLL_BAR_H_
|