diff options
Diffstat (limited to 'scene/gui/scroll_bar.cpp')
-rw-r--r-- | scene/gui/scroll_bar.cpp | 519 |
1 files changed, 233 insertions, 286 deletions
diff --git a/scene/gui/scroll_bar.cpp b/scene/gui/scroll_bar.cpp index b2ad74eaa8..37f7b46e22 100644 --- a/scene/gui/scroll_bar.cpp +++ b/scene/gui/scroll_bar.cpp @@ -28,166 +28,153 @@ /*************************************************************************/ #include "scroll_bar.h" #include "os/keyboard.h" -#include "print_string.h" #include "os/os.h" -bool ScrollBar::focus_by_default=false; - - +#include "print_string.h" +bool ScrollBar::focus_by_default = false; void ScrollBar::set_can_focus_by_default(bool p_can_focus) { - focus_by_default=p_can_focus; + focus_by_default = p_can_focus; } void ScrollBar::_gui_input(InputEvent p_event) { - - switch(p_event.type) { + switch (p_event.type) { case InputEvent::MOUSE_BUTTON: { - const InputEventMouseButton &b=p_event.mouse_button; + const InputEventMouseButton &b = p_event.mouse_button; accept_event(); - if (b.button_index==5 && b.pressed) { + if (b.button_index == 5 && b.pressed) { /* if (orientation==VERTICAL) set_val( get_val() + get_page() / 4.0 ); else */ - set_value( get_value() + get_page() / 4.0 ); + set_value(get_value() + get_page() / 4.0); accept_event(); - } - if (b.button_index==4 && b.pressed) { + if (b.button_index == 4 && b.pressed) { /* if (orientation==HORIZONTAL) set_val( get_val() - get_page() / 4.0 ); else */ - set_value( get_value() - get_page() / 4.0 ); + set_value(get_value() - get_page() / 4.0); accept_event(); } - if (b.button_index!=1) + if (b.button_index != 1) return; - if (b.pressed) { - - double ofs = orientation==VERTICAL ? b.y : b.x ; + double ofs = orientation == VERTICAL ? b.y : b.x; Ref<Texture> decr = get_icon("decrement"); Ref<Texture> incr = get_icon("increment"); - double decr_size = orientation==VERTICAL ? decr->get_height() : decr->get_width(); - double incr_size = orientation==VERTICAL ? incr->get_height() : incr->get_width(); + double decr_size = orientation == VERTICAL ? decr->get_height() : decr->get_width(); + double incr_size = orientation == VERTICAL ? incr->get_height() : incr->get_width(); double grabber_ofs = get_grabber_offset(); double grabber_size = get_grabber_size(); - double total = orientation==VERTICAL ? get_size().height : get_size().width; + double total = orientation == VERTICAL ? get_size().height : get_size().width; - if (ofs < decr_size ) { + if (ofs < decr_size) { - set_value( get_value() - (custom_step>=0?custom_step:get_step()) ); + set_value(get_value() - (custom_step >= 0 ? custom_step : get_step())); break; } - if (ofs > total-incr_size ) { + if (ofs > total - incr_size) { - set_value( get_value() + (custom_step>=0?custom_step:get_step()) ); + set_value(get_value() + (custom_step >= 0 ? custom_step : get_step())); break; } - ofs-=decr_size; + ofs -= decr_size; - if ( ofs < grabber_ofs ) { + if (ofs < grabber_ofs) { - set_value( get_value() - get_page() ); + set_value(get_value() - get_page()); break; - } - ofs-=grabber_ofs; + ofs -= grabber_ofs; - if (ofs < grabber_size ) { + if (ofs < grabber_size) { - drag.active=true; - drag.pos_at_click=grabber_ofs+ofs; - drag.value_at_click=get_as_ratio(); + drag.active = true; + drag.pos_at_click = grabber_ofs + ofs; + drag.value_at_click = get_as_ratio(); update(); } else { - - set_value( get_value() + get_page() ); + set_value(get_value() + get_page()); } - } else { - drag.active=false; + drag.active = false; update(); } } break; case InputEvent::MOUSE_MOTION: { - const InputEventMouseMotion &m=p_event.mouse_motion; + const InputEventMouseMotion &m = p_event.mouse_motion; accept_event(); - if (drag.active) { - double ofs = orientation==VERTICAL ? m.y : m.x ; + double ofs = orientation == VERTICAL ? m.y : m.x; Ref<Texture> decr = get_icon("decrement"); - double decr_size = orientation==VERTICAL ? decr->get_height() : decr->get_width(); - ofs-=decr_size; + double decr_size = orientation == VERTICAL ? decr->get_height() : decr->get_width(); + ofs -= decr_size; - double diff = (ofs-drag.pos_at_click) / get_area_size(); + double diff = (ofs - drag.pos_at_click) / get_area_size(); - set_as_ratio( drag.value_at_click + diff ); + set_as_ratio(drag.value_at_click + diff); } else { - - double ofs = orientation==VERTICAL ? m.y : m.x ; + double ofs = orientation == VERTICAL ? m.y : m.x; Ref<Texture> decr = get_icon("decrement"); Ref<Texture> incr = get_icon("increment"); - double decr_size = orientation==VERTICAL ? decr->get_height() : decr->get_width(); - double incr_size = orientation==VERTICAL ? incr->get_height() : incr->get_width(); - double total = orientation==VERTICAL ? get_size().height : get_size().width; + double decr_size = orientation == VERTICAL ? decr->get_height() : decr->get_width(); + double incr_size = orientation == VERTICAL ? incr->get_height() : incr->get_width(); + double total = orientation == VERTICAL ? get_size().height : get_size().width; HiliteStatus new_hilite; - if (ofs < decr_size ) { + if (ofs < decr_size) { - new_hilite=HILITE_DECR; + new_hilite = HILITE_DECR; - } else if (ofs > total-incr_size ) { + } else if (ofs > total - incr_size) { - new_hilite=HILITE_INCR; + new_hilite = HILITE_INCR; } else { - new_hilite=HILITE_RANGE; + new_hilite = HILITE_RANGE; } - if (new_hilite!=hilite) { + if (new_hilite != hilite) { - hilite=new_hilite; + hilite = new_hilite; update(); - } - } } break; case InputEvent::KEY: { - const InputEventKey &k=p_event.key; + const InputEventKey &k = p_event.key; if (!k.pressed) return; @@ -196,319 +183,298 @@ void ScrollBar::_gui_input(InputEvent p_event) { case KEY_LEFT: { - if (orientation!=HORIZONTAL) + if (orientation != HORIZONTAL) return; - set_value( get_value() - (custom_step>=0?custom_step:get_step()) ); + set_value(get_value() - (custom_step >= 0 ? custom_step : get_step())); } break; case KEY_RIGHT: { - if (orientation!=HORIZONTAL) + if (orientation != HORIZONTAL) return; - set_value( get_value() + (custom_step>=0?custom_step:get_step()) ); + set_value(get_value() + (custom_step >= 0 ? custom_step : get_step())); } break; case KEY_UP: { - if (orientation!=VERTICAL) + if (orientation != VERTICAL) return; - set_value( get_value() - (custom_step>=0?custom_step:get_step()) ); - + set_value(get_value() - (custom_step >= 0 ? custom_step : get_step())); } break; case KEY_DOWN: { - if (orientation!=VERTICAL) + if (orientation != VERTICAL) return; - set_value( get_value() + (custom_step>=0?custom_step:get_step()) ); + set_value(get_value() + (custom_step >= 0 ? custom_step : get_step())); } break; case KEY_HOME: { - set_value( get_min() ); + set_value(get_min()); } break; case KEY_END: { - set_value( get_max() ); + set_value(get_max()); } break; - - } break; + } + break; } } } void ScrollBar::_notification(int p_what) { - if (p_what==NOTIFICATION_DRAW) { + if (p_what == NOTIFICATION_DRAW) { RID ci = get_canvas_item(); - Ref<Texture> decr = hilite==HILITE_DECR ? get_icon("decrement_hilite") : get_icon("decrement"); - Ref<Texture> incr = hilite==HILITE_INCR ? get_icon("increment_hilite") : get_icon("increment"); + Ref<Texture> decr = hilite == HILITE_DECR ? get_icon("decrement_hilite") : get_icon("decrement"); + Ref<Texture> incr = hilite == HILITE_INCR ? get_icon("increment_hilite") : get_icon("increment"); Ref<StyleBox> bg = has_focus() ? get_stylebox("scroll_focus") : get_stylebox("scroll"); - Ref<StyleBox> grabber = (drag.active || hilite==HILITE_RANGE) ? get_stylebox("grabber_hilite") : get_stylebox("grabber"); + Ref<StyleBox> grabber = (drag.active || hilite == HILITE_RANGE) ? get_stylebox("grabber_hilite") : get_stylebox("grabber"); Point2 ofs; VisualServer *vs = VisualServer::get_singleton(); - vs->canvas_item_add_texture_rect( ci, Rect2( Point2(), decr->get_size()),decr->get_rid() ); + vs->canvas_item_add_texture_rect(ci, Rect2(Point2(), decr->get_size()), decr->get_rid()); - if (orientation==HORIZONTAL) - ofs.x+=decr->get_width(); + if (orientation == HORIZONTAL) + ofs.x += decr->get_width(); else - ofs.y+=decr->get_height(); + ofs.y += decr->get_height(); - Size2 area=get_size(); + Size2 area = get_size(); - if (orientation==HORIZONTAL) - area.width-=incr->get_width()+decr->get_width(); + if (orientation == HORIZONTAL) + area.width -= incr->get_width() + decr->get_width(); else - area.height-=incr->get_height()+decr->get_height(); + area.height -= incr->get_height() + decr->get_height(); - bg->draw(ci,Rect2(ofs,area)); + bg->draw(ci, Rect2(ofs, area)); - if (orientation==HORIZONTAL) - ofs.width+=area.width; + if (orientation == HORIZONTAL) + ofs.width += area.width; else - ofs.height+=area.height; + ofs.height += area.height; - vs->canvas_item_add_texture_rect( ci, Rect2( ofs, decr->get_size()),incr->get_rid() ); + vs->canvas_item_add_texture_rect(ci, Rect2(ofs, decr->get_size()), incr->get_rid()); Rect2 grabber_rect; - if (orientation==HORIZONTAL) { + if (orientation == HORIZONTAL) { - grabber_rect.size.width=get_grabber_size(); - grabber_rect.size.height=get_size().height; - grabber_rect.pos.y=0; - grabber_rect.pos.x=get_grabber_offset()+decr->get_width()+bg->get_margin( MARGIN_LEFT ); + grabber_rect.size.width = get_grabber_size(); + grabber_rect.size.height = get_size().height; + grabber_rect.pos.y = 0; + grabber_rect.pos.x = get_grabber_offset() + decr->get_width() + bg->get_margin(MARGIN_LEFT); } else { - grabber_rect.size.width=get_size().width; - grabber_rect.size.height=get_grabber_size(); - grabber_rect.pos.y=get_grabber_offset()+decr->get_height()+bg->get_margin( MARGIN_TOP ); - grabber_rect.pos.x=0; + grabber_rect.size.width = get_size().width; + grabber_rect.size.height = get_grabber_size(); + grabber_rect.pos.y = get_grabber_offset() + decr->get_height() + bg->get_margin(MARGIN_TOP); + grabber_rect.pos.x = 0; } - grabber->draw(ci,grabber_rect); - + grabber->draw(ci, grabber_rect); } - if (p_what==NOTIFICATION_ENTER_TREE) { - + if (p_what == NOTIFICATION_ENTER_TREE) { if (has_node(drag_slave_path)) { Node *n = get_node(drag_slave_path); - drag_slave=n->cast_to<Control>(); + drag_slave = n->cast_to<Control>(); } if (drag_slave) { - drag_slave->connect("gui_input",this,"_drag_slave_input"); - drag_slave->connect("tree_exited",this,"_drag_slave_exit",varray(),CONNECT_ONESHOT); + drag_slave->connect("gui_input", this, "_drag_slave_input"); + drag_slave->connect("tree_exited", this, "_drag_slave_exit", varray(), CONNECT_ONESHOT); } - - } - if (p_what==NOTIFICATION_EXIT_TREE) { + if (p_what == NOTIFICATION_EXIT_TREE) { if (drag_slave) { - drag_slave->disconnect("gui_input",this,"_drag_slave_input"); - drag_slave->disconnect("tree_exited",this,"_drag_slave_exit"); + drag_slave->disconnect("gui_input", this, "_drag_slave_input"); + drag_slave->disconnect("tree_exited", this, "_drag_slave_exit"); } - drag_slave=NULL; - + drag_slave = NULL; } - if (p_what==NOTIFICATION_FIXED_PROCESS) { + if (p_what == NOTIFICATION_FIXED_PROCESS) { - if (drag_slave_touching) { + if (drag_slave_touching) { if (drag_slave_touching_deaccel) { - Vector2 pos = Vector2(orientation==HORIZONTAL?get_value():0,orientation==VERTICAL?get_value():0); - pos+=drag_slave_speed*get_fixed_process_delta_time(); + Vector2 pos = Vector2(orientation == HORIZONTAL ? get_value() : 0, orientation == VERTICAL ? get_value() : 0); + pos += drag_slave_speed * get_fixed_process_delta_time(); - bool turnoff=false; + bool turnoff = false; - if (orientation==HORIZONTAL) { + if (orientation == HORIZONTAL) { - if (pos.x<0) { - pos.x=0; - turnoff=true; + if (pos.x < 0) { + pos.x = 0; + turnoff = true; } - if (pos.x > (get_max()-get_page())) { - pos.x=get_max()-get_page(); - turnoff=true; + if (pos.x > (get_max() - get_page())) { + pos.x = get_max() - get_page(); + turnoff = true; } set_value(pos.x); - float sgn_x = drag_slave_speed.x<0? -1 : 1; + float sgn_x = drag_slave_speed.x < 0 ? -1 : 1; float val_x = Math::abs(drag_slave_speed.x); - val_x-=1000*get_fixed_process_delta_time(); + val_x -= 1000 * get_fixed_process_delta_time(); - if (val_x<0) { - turnoff=true; + if (val_x < 0) { + turnoff = true; } - drag_slave_speed.x=sgn_x*val_x; + drag_slave_speed.x = sgn_x * val_x; } else { - - if (pos.y<0) { - pos.y=0; - turnoff=true; + if (pos.y < 0) { + pos.y = 0; + turnoff = true; } - if (pos.y > (get_max()-get_page())) { - pos.y=get_max()-get_page(); - turnoff=true; + if (pos.y > (get_max() - get_page())) { + pos.y = get_max() - get_page(); + turnoff = true; } set_value(pos.y); - float sgn_y = drag_slave_speed.y<0? -1 : 1; + float sgn_y = drag_slave_speed.y < 0 ? -1 : 1; float val_y = Math::abs(drag_slave_speed.y); - val_y-=1000*get_fixed_process_delta_time(); + val_y -= 1000 * get_fixed_process_delta_time(); - if (val_y<0) { - turnoff=true; + if (val_y < 0) { + turnoff = true; } - drag_slave_speed.y=sgn_y*val_y; + drag_slave_speed.y = sgn_y * val_y; } - if (turnoff) { set_fixed_process(false); - drag_slave_touching=false; - drag_slave_touching_deaccel=false; + drag_slave_touching = false; + drag_slave_touching_deaccel = false; } - } else { - - if (time_since_motion==0 || time_since_motion>0.1) { + if (time_since_motion == 0 || time_since_motion > 0.1) { Vector2 diff = drag_slave_accum - last_drag_slave_accum; - last_drag_slave_accum=drag_slave_accum; - drag_slave_speed=diff/get_fixed_process_delta_time(); + last_drag_slave_accum = drag_slave_accum; + drag_slave_speed = diff / get_fixed_process_delta_time(); } - time_since_motion+=get_fixed_process_delta_time(); + time_since_motion += get_fixed_process_delta_time(); } } - - } - if (p_what==NOTIFICATION_MOUSE_EXIT) { + if (p_what == NOTIFICATION_MOUSE_EXIT) { - hilite=HILITE_NONE; + hilite = HILITE_NONE; update(); } } double ScrollBar::get_grabber_min_size() const { - Ref<StyleBox> grabber=get_stylebox("grabber"); - Size2 gminsize=grabber->get_minimum_size()+grabber->get_center_size(); - return (orientation==VERTICAL)?gminsize.height:gminsize.width; + Ref<StyleBox> grabber = get_stylebox("grabber"); + Size2 gminsize = grabber->get_minimum_size() + grabber->get_center_size(); + return (orientation == VERTICAL) ? gminsize.height : gminsize.width; } double ScrollBar::get_grabber_size() const { - float range = get_max()-get_min(); - if (range<=0) + float range = get_max() - get_min(); + if (range <= 0) return 0; - float page = (get_page()>0)? get_page() : 0; + float page = (get_page() > 0) ? get_page() : 0; /* if (grabber_range < get_step()) grabber_range=get_step(); */ - double area_size=get_area_size(); + double area_size = get_area_size(); double grabber_size = page / range * area_size; - return grabber_size+get_grabber_min_size(); - + return grabber_size + get_grabber_min_size(); } double ScrollBar::get_area_size() const { - if (orientation==VERTICAL) { + if (orientation == VERTICAL) { - double area=get_size().height; - area-=get_stylebox("scroll")->get_minimum_size().height; - area-=get_icon("increment")->get_height(); - area-=get_icon("decrement")->get_height(); - area-=get_grabber_min_size(); + double area = get_size().height; + area -= get_stylebox("scroll")->get_minimum_size().height; + area -= get_icon("increment")->get_height(); + area -= get_icon("decrement")->get_height(); + area -= get_grabber_min_size(); return area; - } else if (orientation==HORIZONTAL) { + } else if (orientation == HORIZONTAL) { - double area=get_size().width; - area-=get_stylebox("scroll")->get_minimum_size().width; - area-=get_icon("increment")->get_width(); - area-=get_icon("decrement")->get_width(); - area-=get_grabber_min_size(); + double area = get_size().width; + area -= get_stylebox("scroll")->get_minimum_size().width; + area -= get_icon("increment")->get_width(); + area -= get_icon("decrement")->get_width(); + area -= get_grabber_min_size(); return area; } else { return 0; } - } double ScrollBar::get_area_offset() const { - double ofs=0; + double ofs = 0; - if (orientation==VERTICAL) { - - ofs+=get_stylebox("hscroll")->get_margin( MARGIN_TOP ); - ofs+=get_icon("decrement")->get_height(); + if (orientation == VERTICAL) { + ofs += get_stylebox("hscroll")->get_margin(MARGIN_TOP); + ofs += get_icon("decrement")->get_height(); } - if (orientation==HORIZONTAL) { + if (orientation == HORIZONTAL) { - ofs+=get_stylebox("hscroll")->get_margin( MARGIN_LEFT ); - ofs+=get_icon("decrement")->get_width(); + ofs += get_stylebox("hscroll")->get_margin(MARGIN_LEFT); + ofs += get_icon("decrement")->get_width(); } return ofs; } -double ScrollBar::get_click_pos(const Point2& p_pos) const { - +double ScrollBar::get_click_pos(const Point2 &p_pos) const { - float pos=(orientation==VERTICAL)?p_pos.y:p_pos.x; - pos-=get_area_offset(); + float pos = (orientation == VERTICAL) ? p_pos.y : p_pos.x; + pos -= get_area_offset(); - float area=get_area_size(); - if (area==0) + float area = get_area_size(); + if (area == 0) return 0; else - return pos/area; - + return pos / area; } double ScrollBar::get_grabber_offset() const { - return (get_area_size()) * get_as_ratio(); - } - - Size2 ScrollBar::get_minimum_size() const { Ref<Texture> incr = get_icon("increment"); @@ -516,31 +482,30 @@ Size2 ScrollBar::get_minimum_size() const { Ref<StyleBox> bg = get_stylebox("scroll"); Size2 minsize; - if (orientation==VERTICAL) { + if (orientation == VERTICAL) { - minsize.width=MAX(incr->get_size().width,(bg->get_minimum_size()+bg->get_center_size()).width); - minsize.height+=incr->get_size().height; - minsize.height+=decr->get_size().height; - minsize.height+=bg->get_minimum_size().height; - minsize.height+=get_grabber_min_size(); + minsize.width = MAX(incr->get_size().width, (bg->get_minimum_size() + bg->get_center_size()).width); + minsize.height += incr->get_size().height; + minsize.height += decr->get_size().height; + minsize.height += bg->get_minimum_size().height; + minsize.height += get_grabber_min_size(); } - if (orientation==HORIZONTAL) { + if (orientation == HORIZONTAL) { - minsize.height=MAX(incr->get_size().height,(bg->get_center_size()+bg->get_minimum_size()).height); - minsize.width+=incr->get_size().width; - minsize.width+=decr->get_size().width; - minsize.width+=bg->get_minimum_size().width; - minsize.width+=get_grabber_min_size(); + minsize.height = MAX(incr->get_size().height, (bg->get_center_size() + bg->get_minimum_size()).height); + minsize.width += incr->get_size().width; + minsize.width += decr->get_size().width; + minsize.width += bg->get_minimum_size().width; + minsize.width += get_grabber_min_size(); } return minsize; - } void ScrollBar::set_custom_step(float p_custom_step) { - custom_step=p_custom_step; + custom_step = p_custom_step; } float ScrollBar::get_custom_step() const { @@ -548,53 +513,50 @@ float ScrollBar::get_custom_step() const { return custom_step; } - void ScrollBar::_drag_slave_exit() { if (drag_slave) { - drag_slave->disconnect("gui_input",this,"_drag_slave_input"); + drag_slave->disconnect("gui_input", this, "_drag_slave_input"); } - drag_slave=NULL; + drag_slave = NULL; } +void ScrollBar::_drag_slave_input(const InputEvent &p_input) { -void ScrollBar::_drag_slave_input(const InputEvent& p_input) { - - switch(p_input.type) { + switch (p_input.type) { case InputEvent::MOUSE_BUTTON: { - const InputEventMouseButton &mb=p_input.mouse_button; + const InputEventMouseButton &mb = p_input.mouse_button; - if (mb.button_index!=1) + if (mb.button_index != 1) break; if (mb.pressed) { if (drag_slave_touching) { set_fixed_process(false); - drag_slave_touching_deaccel=false; - drag_slave_touching=false; - drag_slave_speed=Vector2(); - drag_slave_accum=Vector2(); - last_drag_slave_accum=Vector2(); - drag_slave_from=Vector2(); + drag_slave_touching_deaccel = false; + drag_slave_touching = false; + drag_slave_speed = Vector2(); + drag_slave_accum = Vector2(); + last_drag_slave_accum = Vector2(); + drag_slave_from = Vector2(); } if (true) { - drag_slave_speed=Vector2(); - drag_slave_accum=Vector2(); - last_drag_slave_accum=Vector2(); + drag_slave_speed = Vector2(); + drag_slave_accum = Vector2(); + last_drag_slave_accum = Vector2(); //drag_slave_from=Vector2(h_scroll->get_val(),v_scroll->get_val()); - drag_slave_from= Vector2(orientation==HORIZONTAL?get_value():0,orientation==VERTICAL?get_value():0); + drag_slave_from = Vector2(orientation == HORIZONTAL ? get_value() : 0, orientation == VERTICAL ? get_value() : 0); - drag_slave_touching=OS::get_singleton()->has_touchscreen_ui_hint(); - drag_slave_touching_deaccel=false; - time_since_motion=0; + drag_slave_touching = OS::get_singleton()->has_touchscreen_ui_hint(); + drag_slave_touching_deaccel = false; + time_since_motion = 0; if (drag_slave_touching) { set_fixed_process(true); - time_since_motion=0; - + time_since_motion = 0; } } @@ -602,82 +564,79 @@ void ScrollBar::_drag_slave_input(const InputEvent& p_input) { if (drag_slave_touching) { - if (drag_slave_speed==Vector2()) { - drag_slave_touching_deaccel=false; - drag_slave_touching=false; + if (drag_slave_speed == Vector2()) { + drag_slave_touching_deaccel = false; + drag_slave_touching = false; set_fixed_process(false); } else { - drag_slave_touching_deaccel=true; + drag_slave_touching_deaccel = true; } } } } break; case InputEvent::MOUSE_MOTION: { - const InputEventMouseMotion &mm=p_input.mouse_motion; + const InputEventMouseMotion &mm = p_input.mouse_motion; - if (drag_slave_touching && ! drag_slave_touching_deaccel) { + if (drag_slave_touching && !drag_slave_touching_deaccel) { - Vector2 motion = Vector2(mm.relative_x,mm.relative_y); + Vector2 motion = Vector2(mm.relative_x, mm.relative_y); - drag_slave_accum-=motion; - Vector2 diff = drag_slave_from+drag_slave_accum; + drag_slave_accum -= motion; + Vector2 diff = drag_slave_from + drag_slave_accum; - if (orientation==HORIZONTAL) + if (orientation == HORIZONTAL) set_value(diff.x); /* else drag_slave_accum.x=0; */ - if (orientation==VERTICAL) + if (orientation == VERTICAL) set_value(diff.y); /* else drag_slave_accum.y=0; */ - time_since_motion=0; + time_since_motion = 0; } } break; } } -void ScrollBar::set_drag_slave(const NodePath& p_path) { +void ScrollBar::set_drag_slave(const NodePath &p_path) { if (is_inside_tree()) { if (drag_slave) { - drag_slave->disconnect("gui_input",this,"_drag_slave_input"); - drag_slave->disconnect("tree_exited",this,"_drag_slave_exit"); + drag_slave->disconnect("gui_input", this, "_drag_slave_input"); + drag_slave->disconnect("tree_exited", this, "_drag_slave_exit"); } } - drag_slave=NULL; - drag_slave_path=p_path; + drag_slave = NULL; + drag_slave_path = p_path; if (is_inside_tree()) { if (has_node(p_path)) { Node *n = get_node(p_path); - drag_slave=n->cast_to<Control>(); + drag_slave = n->cast_to<Control>(); } if (drag_slave) { - drag_slave->connect("gui_input",this,"_drag_slave_input"); - drag_slave->connect("tree_exited",this,"_drag_slave_exit",varray(),CONNECT_ONESHOT); + drag_slave->connect("gui_input", this, "_drag_slave_input"); + drag_slave->connect("tree_exited", this, "_drag_slave_exit", varray(), CONNECT_ONESHOT); } } } -NodePath ScrollBar::get_drag_slave() const{ - +NodePath ScrollBar::get_drag_slave() const { return drag_slave_path; } - - #if 0 void ScrollBar::mouse_button(const Point2& p_pos, int b.button_index,bool b.pressed,int p_modifier_mask) { @@ -808,48 +767,36 @@ bool ScrollBar::key(unsigned long p_unicode, unsigned long p_scan_code,bool b.pr return true; } - - #endif void ScrollBar::_bind_methods() { - ClassDB::bind_method(D_METHOD("_gui_input"),&ScrollBar::_gui_input); - ClassDB::bind_method(D_METHOD("set_custom_step","step"),&ScrollBar::set_custom_step); - ClassDB::bind_method(D_METHOD("get_custom_step"),&ScrollBar::get_custom_step); - ClassDB::bind_method(D_METHOD("_drag_slave_input"),&ScrollBar::_drag_slave_input); - ClassDB::bind_method(D_METHOD("_drag_slave_exit"),&ScrollBar::_drag_slave_exit); - - ADD_PROPERTY( PropertyInfo(Variant::REAL,"custom_step",PROPERTY_HINT_RANGE,"-1,4096"), "set_custom_step","get_custom_step"); + ClassDB::bind_method(D_METHOD("_gui_input"), &ScrollBar::_gui_input); + ClassDB::bind_method(D_METHOD("set_custom_step", "step"), &ScrollBar::set_custom_step); + ClassDB::bind_method(D_METHOD("get_custom_step"), &ScrollBar::get_custom_step); + ClassDB::bind_method(D_METHOD("_drag_slave_input"), &ScrollBar::_drag_slave_input); + ClassDB::bind_method(D_METHOD("_drag_slave_exit"), &ScrollBar::_drag_slave_exit); + ADD_PROPERTY(PropertyInfo(Variant::REAL, "custom_step", PROPERTY_HINT_RANGE, "-1,4096"), "set_custom_step", "get_custom_step"); } +ScrollBar::ScrollBar(Orientation p_orientation) { -ScrollBar::ScrollBar(Orientation p_orientation) -{ + orientation = p_orientation; + hilite = HILITE_NONE; + custom_step = -1; + drag_slave = NULL; + drag.active = false; - orientation=p_orientation; - hilite=HILITE_NONE; - custom_step=-1; - drag_slave=NULL; - - drag.active=false; - - drag_slave_speed=Vector2(); - drag_slave_touching=false; - drag_slave_touching_deaccel=false; + drag_slave_speed = Vector2(); + drag_slave_touching = false; + drag_slave_touching_deaccel = false; if (focus_by_default) - set_focus_mode( FOCUS_ALL ); + set_focus_mode(FOCUS_ALL); set_step(0); - } - - -ScrollBar::~ScrollBar() -{ +ScrollBar::~ScrollBar() { } - - |