diff options
Diffstat (limited to 'scene/gui/slider.cpp')
-rw-r--r-- | scene/gui/slider.cpp | 155 |
1 files changed, 73 insertions, 82 deletions
diff --git a/scene/gui/slider.cpp b/scene/gui/slider.cpp index a6d6864b16..365d450ed6 100644 --- a/scene/gui/slider.cpp +++ b/scene/gui/slider.cpp @@ -29,91 +29,88 @@ #include "slider.h" #include "os/keyboard.h" - Size2 Slider::get_minimum_size() const { Ref<StyleBox> style = get_stylebox("slider"); - Size2i ms = style->get_minimum_size()+style->get_center_size(); + Size2i ms = style->get_minimum_size() + style->get_center_size(); return ms; } void Slider::_gui_input(InputEvent p_event) { - - - if (p_event.type==InputEvent::MOUSE_BUTTON) { + if (p_event.type == InputEvent::MOUSE_BUTTON) { InputEventMouseButton &mb = p_event.mouse_button; - if (mb.button_index==BUTTON_LEFT) { + if (mb.button_index == BUTTON_LEFT) { - if (mb.pressed) { - Ref<Texture> grabber = get_icon(mouse_inside||has_focus()?"grabber_hilite":"grabber"); - grab.pos=orientation==VERTICAL?mb.y:mb.x; + if (mb.pressed) { + Ref<Texture> grabber = get_icon(mouse_inside || has_focus() ? "grabber_hilite" : "grabber"); + grab.pos = orientation == VERTICAL ? mb.y : mb.x; double grab_width = (double)grabber->get_size().width; double grab_height = (double)grabber->get_size().height; - double max = orientation==VERTICAL ? get_size().height - grab_height : get_size().width - grab_width; - if (orientation==VERTICAL) - set_as_ratio( 1 - (((double)grab.pos - (grab_height / 2.0)) / max) ); + double max = orientation == VERTICAL ? get_size().height - grab_height : get_size().width - grab_width; + if (orientation == VERTICAL) + set_as_ratio(1 - (((double)grab.pos - (grab_height / 2.0)) / max)); else - set_as_ratio(((double)grab.pos - (grab_width/2.0)) / max); - grab.active=true; - grab.uvalue=get_as_ratio(); + set_as_ratio(((double)grab.pos - (grab_width / 2.0)) / max); + grab.active = true; + grab.uvalue = get_as_ratio(); } else { - grab.active=false; + grab.active = false; } - } else if (mb.pressed && mb.button_index==BUTTON_WHEEL_UP) { + } else if (mb.pressed && mb.button_index == BUTTON_WHEEL_UP) { - set_value( get_value() + get_step()); - } else if (mb.pressed && mb.button_index==BUTTON_WHEEL_DOWN) { - set_value( get_value() - get_step()); + set_value(get_value() + get_step()); + } else if (mb.pressed && mb.button_index == BUTTON_WHEEL_DOWN) { + set_value(get_value() - get_step()); } - } else if (p_event.type==InputEvent::MOUSE_MOTION) { + } else if (p_event.type == InputEvent::MOUSE_MOTION) { if (grab.active) { Size2i size = get_size(); Ref<Texture> grabber = get_icon("grabber"); - float motion = (orientation==VERTICAL?p_event.mouse_motion.y:p_event.mouse_motion.x) - grab.pos; - if (orientation==VERTICAL) - motion=-motion; - float areasize = orientation==VERTICAL?size.height - grabber->get_size().height:size.width - grabber->get_size().width; - if (areasize<=0) + float motion = (orientation == VERTICAL ? p_event.mouse_motion.y : p_event.mouse_motion.x) - grab.pos; + if (orientation == VERTICAL) + motion = -motion; + float areasize = orientation == VERTICAL ? size.height - grabber->get_size().height : size.width - grabber->get_size().width; + if (areasize <= 0) return; float umotion = motion / float(areasize); - set_as_ratio( grab.uvalue + umotion ); + set_as_ratio(grab.uvalue + umotion); } } else { if (p_event.is_action("ui_left") && p_event.is_pressed()) { - 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())); accept_event(); } else if (p_event.is_action("ui_right") && p_event.is_pressed()) { - 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())); accept_event(); } else if (p_event.is_action("ui_up") && p_event.is_pressed()) { - 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())); accept_event(); } else if (p_event.is_action("ui_down") && p_event.is_pressed()) { - 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())); accept_event(); - } else if (p_event.type==InputEvent::KEY) { + } else if (p_event.type == InputEvent::KEY) { - const InputEventKey &k=p_event.key; + const InputEventKey &k = p_event.key; if (!k.pressed) return; @@ -122,35 +119,32 @@ void Slider::_gui_input(InputEvent p_event) { case KEY_HOME: { - set_value( get_min() ); + set_value(get_min()); accept_event(); } break; case KEY_END: { - set_value( get_max() ); + set_value(get_max()); accept_event(); } break; - - } ; + }; } } - } void Slider::_notification(int p_what) { - - switch(p_what) { + switch (p_what) { case NOTIFICATION_MOUSE_ENTER: { - mouse_inside=true; + mouse_inside = true; update(); } break; case NOTIFICATION_MOUSE_EXIT: { - mouse_inside=false; + mouse_inside = false; update(); } break; case NOTIFICATION_DRAW: { @@ -158,45 +152,43 @@ void Slider::_notification(int p_what) { Size2i size = get_size(); Ref<StyleBox> style = get_stylebox("slider"); Ref<StyleBox> focus = get_stylebox("focus"); - Ref<Texture> grabber = get_icon(mouse_inside||has_focus()?"grabber_hilite":"grabber"); + Ref<Texture> grabber = get_icon(mouse_inside || has_focus() ? "grabber_hilite" : "grabber"); Ref<Texture> tick = get_icon("tick"); - if (orientation==VERTICAL) { + if (orientation == VERTICAL) { - style->draw(ci,Rect2i(Point2i(),Size2i(style->get_minimum_size().width+style->get_center_size().width,size.height))); + style->draw(ci, Rect2i(Point2i(), Size2i(style->get_minimum_size().width + style->get_center_size().width, size.height))); /* if (mouse_inside||has_focus()) focus->draw(ci,Rect2i(Point2i(),Size2i(style->get_minimum_size().width+style->get_center_size().width,size.height))); */ float areasize = size.height - grabber->get_size().height; - if (ticks>1) { + if (ticks > 1) { int tickarea = size.height - tick->get_height(); - for(int i=0;i<ticks;i++) { - if( ! ticks_on_borders && (i == 0 || i + 1 == ticks) ) continue; - int ofs = i*tickarea/(ticks-1); - tick->draw(ci,Point2(0,ofs)); + for (int i = 0; i < ticks; i++) { + if (!ticks_on_borders && (i == 0 || i + 1 == ticks)) continue; + int ofs = i * tickarea / (ticks - 1); + tick->draw(ci, Point2(0, ofs)); } - } - grabber->draw(ci,Point2i(size.width/2-grabber->get_size().width/2,size.height - get_as_ratio()*areasize - grabber->get_size().height)); + grabber->draw(ci, Point2i(size.width / 2 - grabber->get_size().width / 2, size.height - get_as_ratio() * areasize - grabber->get_size().height)); } else { - style->draw(ci,Rect2i(Point2i(),Size2i(size.width,style->get_minimum_size().height+style->get_center_size().height))); + style->draw(ci, Rect2i(Point2i(), Size2i(size.width, style->get_minimum_size().height + style->get_center_size().height))); /* if (mouse_inside||has_focus()) focus->draw(ci,Rect2i(Point2i(),Size2i(size.width,style->get_minimum_size().height+style->get_center_size().height))); */ float areasize = size.width - grabber->get_size().width; - if (ticks>1) { + if (ticks > 1) { int tickarea = size.width - tick->get_width(); - for(int i=0;i<ticks;i++) { - if( (! ticks_on_borders) && ( (i == 0) || ((i + 1) == ticks)) ) continue; - int ofs = i*tickarea/(ticks-1); - tick->draw(ci,Point2(ofs,0)); + for (int i = 0; i < ticks; i++) { + if ((!ticks_on_borders) && ((i == 0) || ((i + 1) == ticks))) continue; + int ofs = i * tickarea / (ticks - 1); + tick->draw(ci, Point2(ofs, 0)); } - } - grabber->draw(ci,Point2i(get_as_ratio()*areasize,size.height/2-grabber->get_size().height/2)); + grabber->draw(ci, Point2i(get_as_ratio() * areasize, size.height / 2 - grabber->get_size().height / 2)); } } break; @@ -205,7 +197,7 @@ void Slider::_notification(int p_what) { void Slider::set_custom_step(float p_custom_step) { - custom_step=p_custom_step; + custom_step = p_custom_step; } float Slider::get_custom_step() const { @@ -215,7 +207,7 @@ float Slider::get_custom_step() const { void Slider::set_ticks(int p_count) { - ticks=p_count; + ticks = p_count; update(); } @@ -224,35 +216,34 @@ int Slider::get_ticks() const { return ticks; } -bool Slider::get_ticks_on_borders() const{ +bool Slider::get_ticks_on_borders() const { return ticks_on_borders; } -void Slider::set_ticks_on_borders(bool _tob){ +void Slider::set_ticks_on_borders(bool _tob) { ticks_on_borders = _tob; update(); } void Slider::_bind_methods() { - ClassDB::bind_method(D_METHOD("_gui_input"),&Slider::_gui_input); - ClassDB::bind_method(D_METHOD("set_ticks","count"),&Slider::set_ticks); - ClassDB::bind_method(D_METHOD("get_ticks"),&Slider::get_ticks); - - ClassDB::bind_method(D_METHOD("get_ticks_on_borders"),&Slider::get_ticks_on_borders); - ClassDB::bind_method(D_METHOD("set_ticks_on_borders","ticks_on_border"),&Slider::set_ticks_on_borders); + ClassDB::bind_method(D_METHOD("_gui_input"), &Slider::_gui_input); + ClassDB::bind_method(D_METHOD("set_ticks", "count"), &Slider::set_ticks); + ClassDB::bind_method(D_METHOD("get_ticks"), &Slider::get_ticks); - ADD_PROPERTY( PropertyInfo( Variant::INT, "tick_count", PROPERTY_HINT_RANGE,"0,4096,1"), "set_ticks", "get_ticks") ; - ADD_PROPERTY( PropertyInfo( Variant::BOOL, "ticks_on_borders" ), "set_ticks_on_borders", "get_ticks_on_borders") ; - ADD_PROPERTY( PropertyInfo( Variant::INT,"focus_mode", PROPERTY_HINT_ENUM, "None,Click,All" ), "set_focus_mode", "get_focus_mode") ; + ClassDB::bind_method(D_METHOD("get_ticks_on_borders"), &Slider::get_ticks_on_borders); + ClassDB::bind_method(D_METHOD("set_ticks_on_borders", "ticks_on_border"), &Slider::set_ticks_on_borders); + ADD_PROPERTY(PropertyInfo(Variant::INT, "tick_count", PROPERTY_HINT_RANGE, "0,4096,1"), "set_ticks", "get_ticks"); + ADD_PROPERTY(PropertyInfo(Variant::BOOL, "ticks_on_borders"), "set_ticks_on_borders", "get_ticks_on_borders"); + ADD_PROPERTY(PropertyInfo(Variant::INT, "focus_mode", PROPERTY_HINT_ENUM, "None,Click,All"), "set_focus_mode", "get_focus_mode"); } Slider::Slider(Orientation p_orientation) { - orientation=p_orientation; - mouse_inside=false; - grab.active=false; - ticks=0; - custom_step=-1; + orientation = p_orientation; + mouse_inside = false; + grab.active = false; + ticks = 0; + custom_step = -1; set_focus_mode(FOCUS_ALL); } |