Renamed button functions to be more verboes, same with Range unit value -> ratio

This commit is contained in:
Juan Linietsky 2017-01-13 14:08:30 -03:00
parent e53c247cb1
commit de8cc309d6
10 changed files with 71 additions and 57 deletions

View File

@ -64,7 +64,7 @@ void BaseButton::_gui_input(InputEvent p_event) {
if (status.pressing_button) if (status.pressing_button)
break; break;
if (status.click_on_press) { if (action_mode==ACTION_MODE_BUTTON_PRESS) {
if (b.pressed) { if (b.pressed) {
@ -415,14 +415,14 @@ bool BaseButton::is_toggle_mode() const {
return toggle_mode; return toggle_mode;
} }
void BaseButton::set_click_on_press(bool p_click_on_press) { void BaseButton::set_action_mode(ActionMode p_mode) {
status.click_on_press=p_click_on_press; action_mode=p_mode;
} }
bool BaseButton::get_click_on_press() const { BaseButton::ActionMode BaseButton::get_action_mode() const {
return status.click_on_press; return action_mode;
} }
void BaseButton::set_enabled_focus_mode(FocusMode p_mode) { void BaseButton::set_enabled_focus_mode(FocusMode p_mode) {
@ -514,8 +514,8 @@ void BaseButton::_bind_methods() {
ClassDB::bind_method(_MD("is_toggle_mode"),&BaseButton::is_toggle_mode); ClassDB::bind_method(_MD("is_toggle_mode"),&BaseButton::is_toggle_mode);
ClassDB::bind_method(_MD("set_disabled","disabled"),&BaseButton::set_disabled); ClassDB::bind_method(_MD("set_disabled","disabled"),&BaseButton::set_disabled);
ClassDB::bind_method(_MD("is_disabled"),&BaseButton::is_disabled); ClassDB::bind_method(_MD("is_disabled"),&BaseButton::is_disabled);
ClassDB::bind_method(_MD("set_click_on_press","enable"),&BaseButton::set_click_on_press); ClassDB::bind_method(_MD("set_action_mode","mode"),&BaseButton::set_action_mode);
ClassDB::bind_method(_MD("get_click_on_press"),&BaseButton::get_click_on_press); ClassDB::bind_method(_MD("get_action_mode"),&BaseButton::get_action_mode);
ClassDB::bind_method(_MD("get_draw_mode"),&BaseButton::get_draw_mode); ClassDB::bind_method(_MD("get_draw_mode"),&BaseButton::get_draw_mode);
ClassDB::bind_method(_MD("set_enabled_focus_mode","mode"),&BaseButton::set_enabled_focus_mode); ClassDB::bind_method(_MD("set_enabled_focus_mode","mode"),&BaseButton::set_enabled_focus_mode);
ClassDB::bind_method(_MD("get_enabled_focus_mode"),&BaseButton::get_enabled_focus_mode); ClassDB::bind_method(_MD("get_enabled_focus_mode"),&BaseButton::get_enabled_focus_mode);
@ -536,7 +536,7 @@ void BaseButton::_bind_methods() {
ADD_PROPERTYNZ( PropertyInfo( Variant::BOOL, "disabled"), _SCS("set_disabled"), _SCS("is_disabled")); ADD_PROPERTYNZ( PropertyInfo( Variant::BOOL, "disabled"), _SCS("set_disabled"), _SCS("is_disabled"));
ADD_PROPERTY( PropertyInfo( Variant::BOOL, "toggle_mode"), _SCS("set_toggle_mode"), _SCS("is_toggle_mode")); ADD_PROPERTY( PropertyInfo( Variant::BOOL, "toggle_mode"), _SCS("set_toggle_mode"), _SCS("is_toggle_mode"));
ADD_PROPERTYNZ( PropertyInfo( Variant::BOOL, "is_pressed"), _SCS("set_pressed"), _SCS("is_pressed")); ADD_PROPERTYNZ( PropertyInfo( Variant::BOOL, "is_pressed"), _SCS("set_pressed"), _SCS("is_pressed"));
ADD_PROPERTYNZ( PropertyInfo( Variant::BOOL, "click_on_press"), _SCS("set_click_on_press"), _SCS("get_click_on_press")); ADD_PROPERTYNO( PropertyInfo( Variant::INT, "action_mode",PROPERTY_HINT_ENUM,"Button Press,Button Release"), _SCS("set_action_mode"), _SCS("get_action_mode"));
ADD_PROPERTY( PropertyInfo( Variant::INT,"enabled_focus_mode", PROPERTY_HINT_ENUM, "None,Click,All" ), _SCS("set_enabled_focus_mode"), _SCS("get_enabled_focus_mode") ); ADD_PROPERTY( PropertyInfo( Variant::INT,"enabled_focus_mode", PROPERTY_HINT_ENUM, "None,Click,All" ), _SCS("set_enabled_focus_mode"), _SCS("get_enabled_focus_mode") );
ADD_PROPERTY( PropertyInfo( Variant::OBJECT, "shortcut",PROPERTY_HINT_RESOURCE_TYPE,"ShortCut"), _SCS("set_shortcut"), _SCS("get_shortcut")); ADD_PROPERTY( PropertyInfo( Variant::OBJECT, "shortcut",PROPERTY_HINT_RESOURCE_TYPE,"ShortCut"), _SCS("set_shortcut"), _SCS("get_shortcut"));
ADD_PROPERTY( PropertyInfo( Variant::OBJECT, "group",PROPERTY_HINT_RESOURCE_TYPE,"ButtonGroup"), _SCS("set_button_group"), _SCS("get_button_group")); ADD_PROPERTY( PropertyInfo( Variant::OBJECT, "group",PROPERTY_HINT_RESOURCE_TYPE,"ButtonGroup"), _SCS("set_button_group"), _SCS("get_button_group"));
@ -547,6 +547,10 @@ void BaseButton::_bind_methods() {
BIND_CONSTANT( DRAW_HOVER ); BIND_CONSTANT( DRAW_HOVER );
BIND_CONSTANT( DRAW_DISABLED ); BIND_CONSTANT( DRAW_DISABLED );
BIND_CONSTANT( ACTION_MODE_BUTTON_PRESS );
BIND_CONSTANT( ACTION_MODE_BUTTON_RELEASE );
} }
BaseButton::BaseButton() { BaseButton::BaseButton() {
@ -557,10 +561,10 @@ BaseButton::BaseButton() {
status.hovering=false; status.hovering=false;
status.pressing_inside=false; status.pressing_inside=false;
status.disabled = false; status.disabled = false;
status.click_on_press=false;
status.pressing_button=0; status.pressing_button=0;
set_focus_mode( FOCUS_ALL ); set_focus_mode( FOCUS_ALL );
enabled_focus_mode = FOCUS_ALL; enabled_focus_mode = FOCUS_ALL;
action_mode=ACTION_MODE_BUTTON_RELEASE;
if (button_group.is_valid()) { if (button_group.is_valid()) {

View File

@ -40,11 +40,20 @@ class ButtonGroup;
class BaseButton : public Control { class BaseButton : public Control {
GDCLASS( BaseButton, Control ); GDCLASS( BaseButton, Control );
public:
enum ActionMode {
ACTION_MODE_BUTTON_PRESS,
ACTION_MODE_BUTTON_RELEASE,
};
private:
bool toggle_mode; bool toggle_mode;
FocusMode enabled_focus_mode; FocusMode enabled_focus_mode;
Ref<ShortCut> shortcut; Ref<ShortCut> shortcut;
ActionMode action_mode;
struct Status { struct Status {
bool pressed; bool pressed;
@ -53,7 +62,6 @@ class BaseButton : public Control {
bool pressing_inside; bool pressing_inside;
bool disabled; bool disabled;
bool click_on_press;
int pressing_button; int pressing_button;
} status; } status;
@ -100,8 +108,8 @@ public:
void set_disabled(bool p_disabled); void set_disabled(bool p_disabled);
bool is_disabled() const; bool is_disabled() const;
void set_click_on_press(bool p_click_on_press); void set_action_mode(ActionMode p_mode);
bool get_click_on_press() const; ActionMode get_action_mode() const;
void set_enabled_focus_mode(FocusMode p_mode); void set_enabled_focus_mode(FocusMode p_mode);
FocusMode get_enabled_focus_mode() const; FocusMode get_enabled_focus_mode() const;
@ -120,6 +128,8 @@ public:
}; };
VARIANT_ENUM_CAST( BaseButton::DrawMode ) VARIANT_ENUM_CAST( BaseButton::DrawMode )
VARIANT_ENUM_CAST( BaseButton::ActionMode )
class ButtonGroup : public Resource { class ButtonGroup : public Resource {

View File

@ -117,7 +117,7 @@ MenuButton::MenuButton() {
add_child(popup); add_child(popup);
popup->set_as_toplevel(true); popup->set_as_toplevel(true);
set_process_unhandled_key_input(true); set_process_unhandled_key_input(true);
set_click_on_press(true); set_action_mode(ACTION_MODE_BUTTON_PRESS);
} }

View File

@ -53,7 +53,7 @@ void ProgressBar::_notification(int p_what) {
Color font_color=get_color("font_color"); Color font_color=get_color("font_color");
draw_style_box(bg,Rect2(Point2(),get_size())); draw_style_box(bg,Rect2(Point2(),get_size()));
float r = get_unit_value(); float r = get_as_ratio();
int mp = fg->get_minimum_size().width; int mp = fg->get_minimum_size().width;
int p = r*get_size().width-mp; int p = r*get_size().width-mp;
if (p>0) { if (p>0) {
@ -62,7 +62,7 @@ void ProgressBar::_notification(int p_what) {
} }
if (percent_visible) { if (percent_visible) {
String txt=itos(int(get_unit_value()*100))+"%"; String txt=itos(int(get_as_ratio()*100))+"%";
font->draw_halign(get_canvas_item(),Point2(0,font->get_ascent()+(get_size().height-font->get_height())/2),HALIGN_CENTER,get_size().width,txt,font_color); font->draw_halign(get_canvas_item(),Point2(0,font->get_ascent()+(get_size().height-font->get_height())/2),HALIGN_CENTER,get_size().width,txt,font_color);
} }
} }

View File

@ -135,11 +135,11 @@ double Range::get_page() const {
return shared->page; return shared->page;
} }
void Range::set_unit_value(double p_value) { void Range::set_as_ratio(double p_value) {
double v; double v;
if (shared->exp_unit_value && get_min()>0) { if (shared->exp_ratio && get_min()>0) {
double exp_min = Math::log(get_min())/Math::log(2); double exp_min = Math::log(get_min())/Math::log(2);
double exp_max = Math::log(get_max())/Math::log(2); double exp_max = Math::log(get_max())/Math::log(2);
@ -156,9 +156,9 @@ void Range::set_unit_value(double p_value) {
} }
set_value( v ); set_value( v );
} }
double Range::get_unit_value() const { double Range::get_as_ratio() const {
if (shared->exp_unit_value && get_min()>0) { if (shared->exp_ratio && get_min()>0) {
double exp_min = Math::log(get_min())/Math::log(2); double exp_min = Math::log(get_min())/Math::log(2);
double exp_max = Math::log(get_max())/Math::log(2); double exp_max = Math::log(get_max())/Math::log(2);
@ -227,17 +227,17 @@ void Range::_bind_methods() {
ClassDB::bind_method(_MD("get_max"),&Range::get_max); ClassDB::bind_method(_MD("get_max"),&Range::get_max);
ClassDB::bind_method(_MD("get_step"),&Range::get_step); ClassDB::bind_method(_MD("get_step"),&Range::get_step);
ClassDB::bind_method(_MD("get_page"),&Range::get_page); ClassDB::bind_method(_MD("get_page"),&Range::get_page);
ClassDB::bind_method(_MD("get_unit_value"),&Range::get_unit_value); ClassDB::bind_method(_MD("get_as_ratio"),&Range::get_as_ratio);
ClassDB::bind_method(_MD("set_value","value"),&Range::set_value); ClassDB::bind_method(_MD("set_value","value"),&Range::set_value);
ClassDB::bind_method(_MD("set_min","minimum"),&Range::set_min); ClassDB::bind_method(_MD("set_min","minimum"),&Range::set_min);
ClassDB::bind_method(_MD("set_max","maximum"),&Range::set_max); ClassDB::bind_method(_MD("set_max","maximum"),&Range::set_max);
ClassDB::bind_method(_MD("set_step","step"),&Range::set_step); ClassDB::bind_method(_MD("set_step","step"),&Range::set_step);
ClassDB::bind_method(_MD("set_page","pagesize"),&Range::set_page); ClassDB::bind_method(_MD("set_page","pagesize"),&Range::set_page);
ClassDB::bind_method(_MD("set_unit_value","value"),&Range::set_unit_value); ClassDB::bind_method(_MD("set_as_ratio","value"),&Range::set_as_ratio);
ClassDB::bind_method(_MD("set_rounded_values","enabled"),&Range::set_rounded_values); ClassDB::bind_method(_MD("set_use_rounded_values","enabled"),&Range::set_use_rounded_values);
ClassDB::bind_method(_MD("is_rounded_values"),&Range::is_rounded_values); ClassDB::bind_method(_MD("is_using_rounded_values"),&Range::is_using_rounded_values);
ClassDB::bind_method(_MD("set_exp_unit_value","enabled"),&Range::set_exp_unit_value); ClassDB::bind_method(_MD("set_exp_ratio","enabled"),&Range::set_exp_ratio);
ClassDB::bind_method(_MD("is_unit_value_exp"),&Range::is_unit_value_exp); ClassDB::bind_method(_MD("is_ratio_exp"),&Range::is_ratio_exp);
ClassDB::bind_method(_MD("share","with"),&Range::_share); ClassDB::bind_method(_MD("share","with"),&Range::_share);
ClassDB::bind_method(_MD("unshare"),&Range::unshare); ClassDB::bind_method(_MD("unshare"),&Range::unshare);
@ -250,29 +250,29 @@ void Range::_bind_methods() {
ADD_PROPERTY( PropertyInfo( Variant::REAL, "step" ), _SCS("set_step"), _SCS("get_step") ); ADD_PROPERTY( PropertyInfo( Variant::REAL, "step" ), _SCS("set_step"), _SCS("get_step") );
ADD_PROPERTY( PropertyInfo( Variant::REAL, "page" ), _SCS("set_page"), _SCS("get_page") ); ADD_PROPERTY( PropertyInfo( Variant::REAL, "page" ), _SCS("set_page"), _SCS("get_page") );
ADD_PROPERTY( PropertyInfo( Variant::REAL, "value" ), _SCS("set_value"), _SCS("get_value") ); ADD_PROPERTY( PropertyInfo( Variant::REAL, "value" ), _SCS("set_value"), _SCS("get_value") );
ADD_PROPERTY( PropertyInfo( Variant::BOOL, "exp_edit" ), _SCS("set_exp_unit_value"), _SCS("is_unit_value_exp") ); ADD_PROPERTY( PropertyInfo( Variant::BOOL, "exp_edit" ), _SCS("set_exp_ratio"), _SCS("is_ratio_exp") );
ADD_PROPERTY( PropertyInfo( Variant::BOOL, "rounded" ), _SCS("set_rounded_values"), _SCS("is_rounded_values") ); ADD_PROPERTY( PropertyInfo( Variant::BOOL, "rounded" ), _SCS("set_use_rounded_values"), _SCS("is_using_rounded_values") );
} }
void Range::set_rounded_values(bool p_enable) { void Range::set_use_rounded_values(bool p_enable) {
_rounded_values = p_enable; _rounded_values = p_enable;
} }
bool Range::is_rounded_values() const { bool Range::is_using_rounded_values() const {
return _rounded_values; return _rounded_values;
} }
void Range::set_exp_unit_value(bool p_enable) { void Range::set_exp_ratio(bool p_enable) {
shared->exp_unit_value=p_enable; shared->exp_ratio=p_enable;
} }
bool Range::is_unit_value_exp() const { bool Range::is_ratio_exp() const {
return shared->exp_unit_value; return shared->exp_ratio;
} }
@ -285,7 +285,7 @@ Range::Range()
shared->step=1; shared->step=1;
shared->page=0; shared->page=0;
shared->owners.insert(this); shared->owners.insert(this);
shared->exp_unit_value=false; shared->exp_ratio=false;
_rounded_values = false; _rounded_values = false;
} }

View File

@ -41,7 +41,7 @@ class Range : public Control {
struct Shared { struct Shared {
double val,min,max; double val,min,max;
double step,page; double step,page;
bool exp_unit_value; bool exp_ratio;
Set<Range*> owners; Set<Range*> owners;
void emit_value_changed(); void emit_value_changed();
void emit_changed(const char *p_what=""); void emit_changed(const char *p_what="");
@ -71,20 +71,20 @@ public:
void set_max(double p_max); void set_max(double p_max);
void set_step(double p_step); void set_step(double p_step);
void set_page(double p_page); void set_page(double p_page);
void set_unit_value(double p_value); void set_as_ratio(double p_value);
double get_value() const; double get_value() const;
double get_min() const; double get_min() const;
double get_max() const; double get_max() const;
double get_step() const; double get_step() const;
double get_page() const; double get_page() const;
double get_unit_value() const; double get_as_ratio() const;
void set_rounded_values(bool p_enable); void set_use_rounded_values(bool p_enable);
bool is_rounded_values() const; bool is_using_rounded_values() const;
void set_exp_unit_value(bool p_enable); void set_exp_ratio(bool p_enable);
bool is_unit_value_exp() const; bool is_ratio_exp() const;
void share(Range *p_range); void share(Range *p_range);
void unshare(); void unshare();

View File

@ -112,7 +112,7 @@ void ScrollBar::_gui_input(InputEvent p_event) {
drag.active=true; drag.active=true;
drag.pos_at_click=grabber_ofs+ofs; drag.pos_at_click=grabber_ofs+ofs;
drag.value_at_click=get_unit_value(); drag.value_at_click=get_as_ratio();
update(); update();
} else { } else {
@ -145,7 +145,7 @@ void ScrollBar::_gui_input(InputEvent p_event) {
double diff = (ofs-drag.pos_at_click) / get_area_size(); double diff = (ofs-drag.pos_at_click) / get_area_size();
set_unit_value( drag.value_at_click + diff ); set_as_ratio( drag.value_at_click + diff );
} else { } else {
@ -497,7 +497,7 @@ double ScrollBar::get_click_pos(const Point2& p_pos) const {
double ScrollBar::get_grabber_offset() const { double ScrollBar::get_grabber_offset() const {
return (get_area_size()) * get_unit_value(); return (get_area_size()) * get_as_ratio();
} }

View File

@ -53,11 +53,11 @@ void Slider::_gui_input(InputEvent p_event) {
double grab_height = (double)grabber->get_size().height; double grab_height = (double)grabber->get_size().height;
double max = orientation==VERTICAL ? get_size().height - grab_height : get_size().width - grab_width; double max = orientation==VERTICAL ? get_size().height - grab_height : get_size().width - grab_width;
if (orientation==VERTICAL) if (orientation==VERTICAL)
set_unit_value( 1 - (((double)grab.pos - (grab_height / 2.0)) / max) ); set_as_ratio( 1 - (((double)grab.pos - (grab_height / 2.0)) / max) );
else else
set_unit_value(((double)grab.pos - (grab_width/2.0)) / max); set_as_ratio(((double)grab.pos - (grab_width/2.0)) / max);
grab.active=true; grab.active=true;
grab.uvalue=get_unit_value(); grab.uvalue=get_as_ratio();
} else { } else {
grab.active=false; grab.active=false;
} }
@ -81,7 +81,7 @@ void Slider::_gui_input(InputEvent p_event) {
if (areasize<=0) if (areasize<=0)
return; return;
float umotion = motion / float(areasize); float umotion = motion / float(areasize);
set_unit_value( grab.uvalue + umotion ); set_as_ratio( grab.uvalue + umotion );
} }
} else { } else {
@ -176,7 +176,7 @@ void Slider::_notification(int p_what) {
} }
} }
grabber->draw(ci,Point2i(size.width/2-grabber->get_size().width/2,size.height - get_unit_value()*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 { } 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()) //if (mouse_inside||has_focus())
@ -192,7 +192,7 @@ void Slider::_notification(int p_what) {
} }
} }
grabber->draw(ci,Point2i(get_unit_value()*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; } break;

View File

@ -135,24 +135,24 @@ void TextureProgress::_notification(int p_what){
Size2 s = progress->get_size(); Size2 s = progress->get_size();
switch (mode) { switch (mode) {
case FILL_LEFT_TO_RIGHT: { case FILL_LEFT_TO_RIGHT: {
Rect2 region=Rect2(Point2(),Size2(s.x*get_unit_value(),s.y)); Rect2 region=Rect2(Point2(),Size2(s.x*get_as_ratio(),s.y));
draw_texture_rect_region(progress,region,region); draw_texture_rect_region(progress,region,region);
} break; } break;
case FILL_RIGHT_TO_LEFT: { case FILL_RIGHT_TO_LEFT: {
Rect2 region=Rect2(Point2(s.x-s.x*get_unit_value(),0),Size2(s.x*get_unit_value(),s.y)); Rect2 region=Rect2(Point2(s.x-s.x*get_as_ratio(),0),Size2(s.x*get_as_ratio(),s.y));
draw_texture_rect_region(progress,region,region); draw_texture_rect_region(progress,region,region);
} break; } break;
case FILL_TOP_TO_BOTTOM: { case FILL_TOP_TO_BOTTOM: {
Rect2 region=Rect2(Point2(),Size2(s.x,s.y*get_unit_value())); Rect2 region=Rect2(Point2(),Size2(s.x,s.y*get_as_ratio()));
draw_texture_rect_region(progress,region,region); draw_texture_rect_region(progress,region,region);
} break; } break;
case FILL_BOTTOM_TO_TOP: { case FILL_BOTTOM_TO_TOP: {
Rect2 region=Rect2(Point2(0,s.y-s.y*get_unit_value()),Size2(s.x,s.y*get_unit_value())); Rect2 region=Rect2(Point2(0,s.y-s.y*get_as_ratio()),Size2(s.x,s.y*get_as_ratio()));
draw_texture_rect_region(progress,region,region); draw_texture_rect_region(progress,region,region);
} break; } break;
case FILL_CLOCKWISE: case FILL_CLOCKWISE:
case FILL_COUNTER_CLOCKWISE: { case FILL_COUNTER_CLOCKWISE: {
float val=get_unit_value()*rad_max_degrees/360; float val=get_as_ratio()*rad_max_degrees/360;
if (val==1) { if (val==1) {
Rect2 region=Rect2(Point2(),s); Rect2 region=Rect2(Point2(),s);
draw_texture_rect_region(progress,region,region); draw_texture_rect_region(progress,region,region);
@ -192,7 +192,7 @@ void TextureProgress::_notification(int p_what){
} }
} break; } break;
default: default:
draw_texture_rect_region(progress,Rect2(Point2(),Size2(s.x*get_unit_value(),s.y)),Rect2(Point2(),Size2(s.x*get_unit_value(),s.y))); draw_texture_rect_region(progress,Rect2(Point2(),Size2(s.x*get_as_ratio(),s.y)),Rect2(Point2(),Size2(s.x*get_as_ratio(),s.y)));
} }

View File

@ -2567,7 +2567,7 @@ bool Tree::edit_selected() {
value_editor->set_max( c.max ); value_editor->set_max( c.max );
value_editor->set_step( c.step ); value_editor->set_step( c.step );
value_editor->set_value( c.val ); value_editor->set_value( c.val );
value_editor->set_exp_unit_value( c.expr ); value_editor->set_exp_ratio( c.expr );
updating_value_editor=false; updating_value_editor=false;
} }