diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/widget.cpp | 32 | ||||
-rw-r--r-- | src/widget_type.h | 126 | ||||
-rw-r--r-- | src/window.cpp | 32 | ||||
-rw-r--r-- | src/window_gui.h | 126 |
4 files changed, 158 insertions, 158 deletions
diff --git a/src/widget.cpp b/src/widget.cpp index 7c6447d0a..698217670 100644 --- a/src/widget.cpp +++ b/src/widget.cpp @@ -1633,6 +1633,38 @@ void NWidgetViewport::UpdateViewportCoordinates(Window *w) } /** + * Compute the row of a scrolled widget that a user clicked in. + * @param clickpos Vertical position of the mouse click (without taking scrolling into account). + * @param widget Widget number of the widget clicked in. + * @param padding Amount of empty space between the widget edge and the top of the first row. Default value is \c 0. + * @param line_height Height of a single row. A negative value means using the vertical resize step of the widget. + * @return Row number clicked at. If clicked at a wrong position, #INT_MAX is returned. + */ +int Scrollbar::GetScrolledRowFromWidget(int clickpos, const Window * const w, int widget, int padding, int line_height) const +{ + uint pos = w->GetRowFromWidget(clickpos, widget, padding, line_height); + if (pos != INT_MAX) pos += this->GetPosition(); + return (pos >= this->GetCount()) ? INT_MAX : pos; +} + +/** + * Set capacity of visible elements from the size and resize properties of a widget. + * @param w Window. + * @param widget Widget with size and resize properties. + * @param padding Padding to subtract from the size. + * @note Updates the position if needed. + */ +void Scrollbar::SetCapacityFromWidget(Window *w, int widget, int padding) +{ + NWidgetBase *nwid = w->GetWidget<NWidgetBase>(widget); + if (this->is_vertical) { + this->SetCapacity(((int)nwid->current_y - padding) / (int)nwid->resize_y); + } else { + this->SetCapacity(((int)nwid->current_x - padding) / (int)nwid->resize_x); + } +} + +/** * Scrollbar widget. * @param tp Scrollbar type. (horizontal/vertical) * @param colour Colour of the scrollbar. diff --git a/src/widget_type.h b/src/widget_type.h index f61937aa8..7b5597ed7 100644 --- a/src/widget_type.h +++ b/src/widget_type.h @@ -502,6 +502,132 @@ public: }; /** + * Scrollbar data structure + */ +class Scrollbar { +private: + const bool is_vertical; ///< Scrollbar has vertical orientation. + uint16 count; ///< Number of elements in the list. + uint16 cap; ///< Number of visible elements of the scroll bar. + uint16 pos; ///< Index of first visible item of the list. + +public: + Scrollbar(bool is_vertical) : is_vertical(is_vertical) + { + } + + /** + * Gets the number of elements in the list + * @return the number of elements + */ + FORCEINLINE uint16 GetCount() const + { + return this->count; + } + + /** + * Gets the number of visible elements of the scrollbar + * @return the number of visible elements + */ + FORCEINLINE uint16 GetCapacity() const + { + return this->cap; + } + + /** + * Gets the position of the first visible element in the list + * @return the position of the element + */ + FORCEINLINE uint16 GetPosition() const + { + return this->pos; + } + + /** + * Checks whether given current item is visible in the list + * @param item to check + * @return true iff the item is visible + */ + FORCEINLINE bool IsVisible(uint16 item) const + { + return IsInsideBS(item, this->GetPosition(), this->GetCapacity()); + } + + /** + * Sets the number of elements in the list + * @param num the number of elements in the list + * @note updates the position if needed + */ + void SetCount(int num) + { + assert(num >= 0); + assert(num <= MAX_UVALUE(uint16)); + + this->count = num; + num -= this->cap; + if (num < 0) num = 0; + if (num < this->pos) this->pos = num; + } + + /** + * Set the capacity of visible elements. + * @param capacity the new capacity + * @note updates the position if needed + */ + void SetCapacity(int capacity) + { + assert(capacity > 0); + assert(capacity <= MAX_UVALUE(uint16)); + + this->cap = capacity; + if (this->cap + this->pos > this->count) this->pos = max(0, this->count - this->cap); + } + + void SetCapacityFromWidget(Window *w, int widget, int padding = 0); + + /** + * Sets the position of the first visible element + * @param position the position of the element + */ + void SetPosition(int position) + { + assert(position >= 0); + assert(this->count <= this->cap ? (position == 0) : (position + this->cap <= this->count)); + this->pos = position; + } + + /** + * Updates the position of the first visible element by the given amount. + * If the position would be too low or high it will be clamped appropriately + * @param difference the amount of change requested + */ + void UpdatePosition(int difference) + { + if (difference == 0) return; + this->SetPosition(Clamp(this->pos + difference, 0, max(this->count - this->cap, 0))); + } + + /** + * Scroll towards the given position; if the item is visible nothing + * happens, otherwise it will be shown either at the bottom or top of + * the window depending on where in the list it was. + * @param position the position to scroll towards. + */ + void ScrollTowards(int position) + { + if (position < this->GetPosition()) { + /* scroll up to the item */ + this->SetPosition(position); + } else if (position >= this->GetPosition() + this->GetCapacity()) { + /* scroll down so that the item is at the bottom */ + this->SetPosition(position - this->GetCapacity() + 1); + } + } + + int GetScrolledRowFromWidget(int clickpos, const Window * const w, int widget, int padding = 0, int line_height = -1) const; +}; + +/** * Nested widget to display and control a scrollbar in a window. * Also assign the scrollbar to other widgets using #SetScrollbar() to make the mousewheel work. * @ingroup NestedWidgets diff --git a/src/window.cpp b/src/window.cpp index 3919bf674..469e0c26b 100644 --- a/src/window.cpp +++ b/src/window.cpp @@ -98,38 +98,6 @@ int Window::GetRowFromWidget(int clickpos, int widget, int padding, int line_hei } /** - * Compute the row of a scrolled widget that a user clicked in. - * @param clickpos Vertical position of the mouse click (without taking scrolling into account). - * @param widget Widget number of the widget clicked in. - * @param padding Amount of empty space between the widget edge and the top of the first row. Default value is \c 0. - * @param line_height Height of a single row. A negative value means using the vertical resize step of the widget. - * @return Row number clicked at. If clicked at a wrong position, #INT_MAX is returned. - */ -int Scrollbar::GetScrolledRowFromWidget(int clickpos, const Window * const w, int widget, int padding, int line_height) const -{ - uint pos = w->GetRowFromWidget(clickpos, widget, padding, line_height); - if (pos != INT_MAX) pos += this->GetPosition(); - return (pos >= this->GetCount()) ? INT_MAX : pos; -} - -/** - * Set capacity of visible elements from the size and resize properties of a widget. - * @param w Window. - * @param widget Widget with size and resize properties. - * @param padding Padding to subtract from the size. - * @note Updates the position if needed. - */ -void Scrollbar::SetCapacityFromWidget(Window *w, int widget, int padding) -{ - NWidgetBase *nwid = w->GetWidget<NWidgetBase>(widget); - if (this->is_vertical) { - this->SetCapacity(((int)nwid->current_y - padding) / (int)nwid->resize_y); - } else { - this->SetCapacity(((int)nwid->current_x - padding) / (int)nwid->resize_x); - } -} - -/** * Return the Scrollbar to a widget index. * @param widnum Scrollbar widget index * @return Scrollbar to the widget diff --git a/src/window_gui.h b/src/window_gui.h index 9c7192399..852ec5977 100644 --- a/src/window_gui.h +++ b/src/window_gui.h @@ -184,132 +184,6 @@ enum WindowDefaultFlag { }; /** - * Scrollbar data structure - */ -class Scrollbar { -private: - const bool is_vertical; ///< Scrollbar has vertical orientation. - uint16 count; ///< Number of elements in the list. - uint16 cap; ///< Number of visible elements of the scroll bar. - uint16 pos; ///< Index of first visible item of the list. - -public: - Scrollbar(bool is_vertical) : is_vertical(is_vertical) - { - } - - /** - * Gets the number of elements in the list - * @return the number of elements - */ - FORCEINLINE uint16 GetCount() const - { - return this->count; - } - - /** - * Gets the number of visible elements of the scrollbar - * @return the number of visible elements - */ - FORCEINLINE uint16 GetCapacity() const - { - return this->cap; - } - - /** - * Gets the position of the first visible element in the list - * @return the position of the element - */ - FORCEINLINE uint16 GetPosition() const - { - return this->pos; - } - - /** - * Checks whether given current item is visible in the list - * @param item to check - * @return true iff the item is visible - */ - FORCEINLINE bool IsVisible(uint16 item) const - { - return IsInsideBS(item, this->GetPosition(), this->GetCapacity()); - } - - /** - * Sets the number of elements in the list - * @param num the number of elements in the list - * @note updates the position if needed - */ - void SetCount(int num) - { - assert(num >= 0); - assert(num <= MAX_UVALUE(uint16)); - - this->count = num; - num -= this->cap; - if (num < 0) num = 0; - if (num < this->pos) this->pos = num; - } - - /** - * Set the capacity of visible elements. - * @param capacity the new capacity - * @note updates the position if needed - */ - void SetCapacity(int capacity) - { - assert(capacity > 0); - assert(capacity <= MAX_UVALUE(uint16)); - - this->cap = capacity; - if (this->cap + this->pos > this->count) this->pos = max(0, this->count - this->cap); - } - - void SetCapacityFromWidget(Window *w, int widget, int padding = 0); - - /** - * Sets the position of the first visible element - * @param position the position of the element - */ - void SetPosition(int position) - { - assert(position >= 0); - assert(this->count <= this->cap ? (position == 0) : (position + this->cap <= this->count)); - this->pos = position; - } - - /** - * Updates the position of the first visible element by the given amount. - * If the position would be too low or high it will be clamped appropriately - * @param difference the amount of change requested - */ - void UpdatePosition(int difference) - { - if (difference == 0) return; - this->SetPosition(Clamp(this->pos + difference, 0, max(this->count - this->cap, 0))); - } - - /** - * Scroll towards the given position; if the item is visible nothing - * happens, otherwise it will be shown either at the bottom or top of - * the window depending on where in the list it was. - * @param position the position to scroll towards. - */ - void ScrollTowards(int position) - { - if (position < this->GetPosition()) { - /* scroll up to the item */ - this->SetPosition(position); - } else if (position >= this->GetPosition() + this->GetCapacity()) { - /* scroll down so that the item is at the bottom */ - this->SetPosition(position - this->GetCapacity() + 1); - } - } - - int GetScrolledRowFromWidget(int clickpos, const Window * const w, int widget, int padding = 0, int line_height = -1) const; -}; - -/** * Data structure for resizing a window */ struct ResizeInfo { |