2023-01-05 13:25:55 +01:00
|
|
|
/**************************************************************************/
|
|
|
|
/* scroll_container.h */
|
|
|
|
/**************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* GODOT ENGINE */
|
|
|
|
/* https://godotengine.org */
|
|
|
|
/**************************************************************************/
|
|
|
|
/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
|
|
|
|
/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
|
|
|
|
/* */
|
|
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
|
|
/* a copy of this software and associated documentation files (the */
|
|
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
|
|
/* the following conditions: */
|
|
|
|
/* */
|
|
|
|
/* The above copyright notice and this permission notice shall be */
|
|
|
|
/* included in all copies or substantial portions of the Software. */
|
|
|
|
/* */
|
|
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
|
|
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
|
|
/**************************************************************************/
|
2018-01-05 00:50:27 +01:00
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
#ifndef SCROLL_CONTAINER_H
|
|
|
|
#define SCROLL_CONTAINER_H
|
|
|
|
|
|
|
|
#include "container.h"
|
|
|
|
|
|
|
|
#include "scroll_bar.h"
|
|
|
|
|
|
|
|
class ScrollContainer : public Container {
|
2017-01-03 03:03:46 +01:00
|
|
|
GDCLASS(ScrollContainer, Container);
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2021-12-07 17:15:18 +01:00
|
|
|
public:
|
|
|
|
enum ScrollMode {
|
|
|
|
SCROLL_MODE_DISABLED = 0,
|
|
|
|
SCROLL_MODE_AUTO,
|
|
|
|
SCROLL_MODE_SHOW_ALWAYS,
|
|
|
|
SCROLL_MODE_SHOW_NEVER,
|
|
|
|
};
|
|
|
|
|
|
|
|
private:
|
2022-04-04 15:06:57 +02:00
|
|
|
HScrollBar *h_scroll = nullptr;
|
|
|
|
VScrollBar *v_scroll = nullptr;
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2022-07-23 14:53:46 +02:00
|
|
|
mutable Size2 largest_child_min_size; // The largest one among the min sizes of all available child controls.
|
2014-02-10 02:10:30 +01:00
|
|
|
|
|
|
|
void update_scrollbars();
|
|
|
|
|
|
|
|
Vector2 drag_speed;
|
|
|
|
Vector2 drag_accum;
|
|
|
|
Vector2 drag_from;
|
|
|
|
Vector2 last_drag_accum;
|
2021-04-18 22:38:44 +02:00
|
|
|
float time_since_motion = 0.0f;
|
2021-02-09 18:24:36 +01:00
|
|
|
bool drag_touching = false;
|
|
|
|
bool drag_touching_deaccel = false;
|
|
|
|
bool beyond_deadzone = false;
|
|
|
|
|
2021-12-07 17:15:18 +01:00
|
|
|
ScrollMode horizontal_scroll_mode = SCROLL_MODE_AUTO;
|
|
|
|
ScrollMode vertical_scroll_mode = SCROLL_MODE_AUTO;
|
2021-04-18 22:38:44 +02:00
|
|
|
|
2021-02-09 18:24:36 +01:00
|
|
|
int deadzone = 0;
|
|
|
|
bool follow_focus = false;
|
2018-02-27 16:37:20 +01:00
|
|
|
|
2022-08-31 14:02:40 +02:00
|
|
|
struct ThemeCache {
|
2022-09-06 19:09:32 +02:00
|
|
|
Ref<StyleBox> panel_style;
|
2022-08-31 14:02:40 +02:00
|
|
|
} theme_cache;
|
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
void _cancel_drag();
|
|
|
|
|
|
|
|
protected:
|
2020-07-10 12:34:39 +02:00
|
|
|
Size2 get_minimum_size() const override;
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2021-05-15 05:19:23 +02:00
|
|
|
void _gui_focus_changed(Control *p_control);
|
2022-07-23 14:53:46 +02:00
|
|
|
void _reposition_children();
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2023-09-08 21:00:10 +02:00
|
|
|
void _notification(int p_what);
|
2014-02-10 02:10:30 +01:00
|
|
|
static void _bind_methods();
|
|
|
|
|
2020-09-03 13:22:16 +02:00
|
|
|
bool _updating_scrollbars = false;
|
2020-01-16 04:36:31 +01:00
|
|
|
void _update_scrollbar_position();
|
2023-09-08 21:00:10 +02:00
|
|
|
void _scroll_moved(float);
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
public:
|
2021-12-02 15:57:53 +01:00
|
|
|
virtual void gui_input(const Ref<InputEvent> &p_gui_input) override;
|
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
void set_h_scroll(int p_pos);
|
2021-04-18 22:38:44 +02:00
|
|
|
int get_h_scroll() const;
|
|
|
|
|
|
|
|
void set_v_scroll(int p_pos);
|
|
|
|
int get_v_scroll() const;
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2023-01-03 10:36:44 +01:00
|
|
|
void set_horizontal_custom_step(float p_custom_step);
|
|
|
|
float get_horizontal_custom_step() const;
|
|
|
|
|
|
|
|
void set_vertical_custom_step(float p_custom_step);
|
|
|
|
float get_vertical_custom_step() const;
|
|
|
|
|
2021-12-07 17:15:18 +01:00
|
|
|
void set_horizontal_scroll_mode(ScrollMode p_mode);
|
|
|
|
ScrollMode get_horizontal_scroll_mode() const;
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2021-12-07 17:15:18 +01:00
|
|
|
void set_vertical_scroll_mode(ScrollMode p_mode);
|
|
|
|
ScrollMode get_vertical_scroll_mode() const;
|
2021-04-18 22:38:44 +02:00
|
|
|
|
2018-02-27 16:37:20 +01:00
|
|
|
int get_deadzone() const;
|
|
|
|
void set_deadzone(int p_deadzone);
|
|
|
|
|
2019-12-24 00:03:24 +01:00
|
|
|
bool is_following_focus() const;
|
2019-12-30 23:42:39 +01:00
|
|
|
void set_follow_focus(bool p_follow);
|
2019-12-24 00:03:24 +01:00
|
|
|
|
2021-11-30 17:46:36 +01:00
|
|
|
HScrollBar *get_h_scroll_bar();
|
|
|
|
VScrollBar *get_v_scroll_bar();
|
2021-05-15 05:19:23 +02:00
|
|
|
void ensure_control_visible(Control *p_control);
|
2018-06-07 17:46:14 +02:00
|
|
|
|
2023-07-05 15:41:44 +02:00
|
|
|
Array get_configuration_warnings() const override;
|
2017-01-09 19:50:08 +01:00
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
ScrollContainer();
|
|
|
|
};
|
|
|
|
|
2021-12-07 17:15:18 +01:00
|
|
|
VARIANT_ENUM_CAST(ScrollContainer::ScrollMode);
|
|
|
|
|
2022-07-23 23:41:51 +02:00
|
|
|
#endif // SCROLL_CONTAINER_H
|