Merge pull request #31654 from Paulb23/minimap_fixes

Viewport highlight, colour cache and minimap scrolling fixes.
This commit is contained in:
Rémi Verschelde 2019-08-25 22:32:05 +02:00 committed by GitHub
commit 41b5c62952
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 47 additions and 36 deletions

View File

@ -559,7 +559,7 @@ void TextEdit::_update_selection_mode_line() {
click_select_held->start(); click_select_held->start();
} }
void TextEdit::_update_minimap_scroll() { void TextEdit::_update_minimap_click() {
Point2 mp = get_local_mouse_position(); Point2 mp = get_local_mouse_position();
int xmargin_end = get_size().width - cache.style_normal->get_margin(MARGIN_RIGHT); int xmargin_end = get_size().width - cache.style_normal->get_margin(MARGIN_RIGHT);
@ -573,6 +573,13 @@ void TextEdit::_update_minimap_scroll() {
int row; int row;
_get_minimap_mouse_row(Point2i(mp.x, mp.y), row); _get_minimap_mouse_row(Point2i(mp.x, mp.y), row);
if (row >= get_first_visible_line() && (row < get_last_visible_line() || row >= (text.size() - 1))) {
minimap_scroll_ratio = v_scroll->get_as_ratio();
minimap_scroll_click_pos = mp.y;
can_drag_minimap = true;
return;
}
int wi; int wi;
int first_line = row - num_lines_from_rows(row, 0, -get_visible_rows() / 2, wi) + 1; int first_line = row - num_lines_from_rows(row, 0, -get_visible_rows() / 2, wi) + 1;
double delta = get_scroll_pos_for_line(first_line, wi) - get_v_scroll(); double delta = get_scroll_pos_for_line(first_line, wi) - get_v_scroll();
@ -583,6 +590,17 @@ void TextEdit::_update_minimap_scroll() {
} }
} }
void TextEdit::_update_minimap_drag() {
if (!can_drag_minimap) {
return;
}
Point2 mp = get_local_mouse_position();
double diff = (mp.y - minimap_scroll_click_pos) / _get_control_height();
v_scroll->set_as_ratio(minimap_scroll_ratio + diff);
}
void TextEdit::_notification(int p_what) { void TextEdit::_notification(int p_what) {
switch (p_what) { switch (p_what) {
@ -899,12 +917,7 @@ void TextEdit::_notification(int p_what) {
// calculate viewport size and y offset // calculate viewport size and y offset
int viewport_height = (draw_amount - 1) * minimap_line_height; int viewport_height = (draw_amount - 1) * minimap_line_height;
int control_height = size.height; int control_height = _get_control_height() - viewport_height;
control_height -= cache.style_normal->get_minimum_size().height;
if (h_scroll->is_visible_in_tree()) {
control_height -= h_scroll->get_size().height;
}
control_height -= viewport_height;
int viewport_offset_y = round(get_scroll_pos_for_line(first_visible_line) * control_height) / ((v_scroll->get_max() <= minimap_visible_lines) ? (minimap_visible_lines - draw_amount) : (v_scroll->get_max() - draw_amount)); int viewport_offset_y = round(get_scroll_pos_for_line(first_visible_line) * control_height) / ((v_scroll->get_max() <= minimap_visible_lines) ? (minimap_visible_lines - draw_amount) : (v_scroll->get_max() - draw_amount));
// calculate the first line. // calculate the first line.
@ -918,8 +931,7 @@ void TextEdit::_notification(int p_what) {
int minimap_draw_amount = minimap_visible_lines + times_line_wraps(minimap_line + 1); int minimap_draw_amount = minimap_visible_lines + times_line_wraps(minimap_line + 1);
// draw the minimap // draw the minimap
Color viewport_color = cache.current_line_color; Color viewport_color = (cache.background_color.get_v() < 0.5) ? Color(1, 1, 1, 0.1) : Color(0, 0, 0, 0.1);
viewport_color.a /= 2;
VisualServer::get_singleton()->canvas_item_add_rect(ci, Rect2((xmargin_end + 2), viewport_offset_y, cache.minimap_width, viewport_height), viewport_color); VisualServer::get_singleton()->canvas_item_add_rect(ci, Rect2((xmargin_end + 2), viewport_offset_y, cache.minimap_width, viewport_height), viewport_color);
for (int i = 0; i < minimap_draw_amount; i++) { for (int i = 0; i < minimap_draw_amount; i++) {
@ -2071,12 +2083,7 @@ void TextEdit::_get_minimap_mouse_row(const Point2i &p_mouse, int &r_row) const
// calculate viewport size and y offset // calculate viewport size and y offset
int viewport_height = (draw_amount - 1) * minimap_line_height; int viewport_height = (draw_amount - 1) * minimap_line_height;
int control_height = get_size().height; int control_height = _get_control_height() - viewport_height;
control_height -= cache.style_normal->get_minimum_size().height;
if (h_scroll->is_visible_in_tree()) {
control_height -= h_scroll->get_size().height;
}
control_height -= viewport_height;
int viewport_offset_y = round(get_scroll_pos_for_line(first_visible_line) * control_height) / ((v_scroll->get_max() <= minimap_visible_lines) ? (minimap_visible_lines - draw_amount) : (v_scroll->get_max() - draw_amount)); int viewport_offset_y = round(get_scroll_pos_for_line(first_visible_line) * control_height) / ((v_scroll->get_max() <= minimap_visible_lines) ? (minimap_visible_lines - draw_amount) : (v_scroll->get_max() - draw_amount));
// calculate the first line. // calculate the first line.
@ -2240,7 +2247,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
// minimap // minimap
if (draw_minimap) { if (draw_minimap) {
_update_minimap_scroll(); _update_minimap_click();
if (dragging_minimap) { if (dragging_minimap) {
return; return;
} }
@ -2363,6 +2370,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
if (mb->get_button_index() == BUTTON_LEFT) { if (mb->get_button_index() == BUTTON_LEFT) {
dragging_minimap = false; dragging_minimap = false;
dragging_selection = false; dragging_selection = false;
can_drag_minimap = false;
click_select_held->stop(); click_select_held->stop();
} }
@ -2411,7 +2419,7 @@ void TextEdit::_gui_input(const Ref<InputEvent> &p_gui_input) {
_reset_caret_blink_timer(); _reset_caret_blink_timer();
if (draw_minimap && !dragging_selection) { if (draw_minimap && !dragging_selection) {
_update_minimap_scroll(); _update_minimap_drag();
} }
if (!dragging_minimap) { if (!dragging_minimap) {
@ -4000,7 +4008,7 @@ void TextEdit::_line_edited_from(int p_line) {
if (syntax_highlighting_cache.size() > 0) { if (syntax_highlighting_cache.size() > 0) {
cache_size = syntax_highlighting_cache.back()->key(); cache_size = syntax_highlighting_cache.back()->key();
for (int i = p_line - 1; i < cache_size; i++) { for (int i = p_line - 1; i <= cache_size; i++) {
if (syntax_highlighting_cache.has(i)) { if (syntax_highlighting_cache.has(i)) {
syntax_highlighting_cache.erase(i); syntax_highlighting_cache.erase(i);
} }
@ -4027,23 +4035,21 @@ Size2 TextEdit::get_minimum_size() const {
return cache.style_normal->get_minimum_size(); return cache.style_normal->get_minimum_size();
} }
int TextEdit::get_visible_rows() const { int TextEdit::_get_control_height() const {
int control_height = get_size().height;
control_height -= cache.style_normal->get_minimum_size().height;
if (h_scroll->is_visible_in_tree()) {
control_height -= h_scroll->get_size().height;
}
return control_height;
}
int total = get_size().height; int TextEdit::get_visible_rows() const {
total -= cache.style_normal->get_minimum_size().height; return _get_control_height() / get_row_height();
if (h_scroll->is_visible_in_tree())
total -= h_scroll->get_size().height;
total /= get_row_height();
return total;
} }
int TextEdit::_get_minimap_visible_rows() const { int TextEdit::_get_minimap_visible_rows() const {
int total = get_size().height; return _get_control_height() / (minimap_char_size.y + minimap_line_spacing);
total -= cache.style_normal->get_minimum_size().height;
if (h_scroll->is_visible_in_tree())
total -= h_scroll->get_size().height;
total /= (minimap_char_size.y + minimap_line_spacing);
return total;
} }
int TextEdit::get_total_visible_rows() const { int TextEdit::get_total_visible_rows() const {
@ -6134,10 +6140,7 @@ int TextEdit::get_last_visible_line_wrap_index() const {
double TextEdit::get_visible_rows_offset() const { double TextEdit::get_visible_rows_offset() const {
double total = get_size().height; double total = _get_control_height();
total -= cache.style_normal->get_minimum_size().height;
if (h_scroll->is_visible_in_tree())
total -= h_scroll->get_size().height;
total /= (double)get_row_height(); total /= (double)get_row_height();
total = total - floor(total); total = total - floor(total);
total = -CLAMP(total, 0.001, 1) + 1; total = -CLAMP(total, 0.001, 1) + 1;
@ -7027,6 +7030,9 @@ TextEdit::TextEdit() {
scrolling = false; scrolling = false;
minimap_clicked = false; minimap_clicked = false;
dragging_minimap = false; dragging_minimap = false;
can_drag_minimap = false;
minimap_scroll_ratio = 0;
minimap_scroll_click_pos = 0;
dragging_selection = false; dragging_selection = false;
target_v_scroll = 0; target_v_scroll = 0;
v_scroll_speed = 80; v_scroll_speed = 80;

View File

@ -334,7 +334,10 @@ private:
bool scrolling; bool scrolling;
bool dragging_selection; bool dragging_selection;
bool dragging_minimap; bool dragging_minimap;
bool can_drag_minimap;
bool minimap_clicked; bool minimap_clicked;
double minimap_scroll_ratio;
double minimap_scroll_click_pos;
float target_v_scroll; float target_v_scroll;
float v_scroll_speed; float v_scroll_speed;
@ -406,7 +409,8 @@ private:
void _update_selection_mode_word(); void _update_selection_mode_word();
void _update_selection_mode_line(); void _update_selection_mode_line();
void _update_minimap_scroll(); void _update_minimap_click();
void _update_minimap_drag();
void _scroll_up(real_t p_delta); void _scroll_up(real_t p_delta);
void _scroll_down(real_t p_delta); void _scroll_down(real_t p_delta);
@ -418,6 +422,7 @@ private:
//void mouse_motion(const Point& p_pos, const Point& p_rel, int p_button_mask); //void mouse_motion(const Point& p_pos, const Point& p_rel, int p_button_mask);
Size2 get_minimum_size() const; Size2 get_minimum_size() const;
int _get_control_height() const;
int get_row_height() const; int get_row_height() const;