diff options
author | Juan Linietsky <reduzio@gmail.com> | 2014-09-17 11:53:29 -0300 |
---|---|---|
committer | Juan Linietsky <reduzio@gmail.com> | 2014-09-17 11:53:29 -0300 |
commit | fa004d5c0fb79e59f81d53ab8f53906a930a8453 (patch) | |
tree | d36a10e4758c5ef93daab7f69a9647d44998d355 /scene/gui | |
parent | 64b01d6ce04350ad9d0cf36bf489426ff7ccd40c (diff) |
Small Fixes
-----------
-Added Ability for centering on top left for centercontainer
-Added ability to bind more than 5 parameters (must include an extra file)
Diffstat (limited to 'scene/gui')
-rw-r--r-- | scene/gui/center_container.cpp | 32 | ||||
-rw-r--r-- | scene/gui/center_container.h | 5 | ||||
-rw-r--r-- | scene/gui/control.cpp | 6 | ||||
-rw-r--r-- | scene/gui/control.h | 2 |
4 files changed, 38 insertions, 7 deletions
diff --git a/scene/gui/center_container.cpp b/scene/gui/center_container.cpp index 9cedf02371..4f8f50781c 100644 --- a/scene/gui/center_container.cpp +++ b/scene/gui/center_container.cpp @@ -32,6 +32,8 @@ Size2 CenterContainer::get_minimum_size() const { + if (use_top_left) + return Size2(); Size2 ms; for(int i=0;i<get_child_count();i++) { @@ -53,6 +55,20 @@ Size2 CenterContainer::get_minimum_size() const { } + +void CenterContainer::set_use_top_left(bool p_enable) { + + use_top_left=p_enable; + queue_sort(); + +} + +bool CenterContainer::is_using_top_left() const { + + return use_top_left; +} + + void CenterContainer::_notification(int p_what) { if (p_what==NOTIFICATION_SORT_CHILDREN) { @@ -65,14 +81,24 @@ void CenterContainer::_notification(int p_what) { continue; if (c->is_set_as_toplevel()) continue; + Size2 minsize = c->get_combined_minimum_size(); - Point2 ofs = ((size - minsize)/2.0).floor(); + Point2 ofs = use_top_left ? (-minsize*0.5).floor() : ((size - minsize)/2.0).floor(); fit_child_in_rect(c,Rect2(ofs,minsize)); } } } -CenterContainer::CenterContainer() -{ +void CenterContainer::_bind_methods() { + + ObjectTypeDB::bind_method(_MD("set_use_top_left","enable"),&CenterContainer::set_use_top_left); + ObjectTypeDB::bind_method(_MD("is_using_top_left"),&CenterContainer::is_using_top_left); + + ADD_PROPERTY( PropertyInfo(Variant::BOOL,"use_top_left"),_SCS("set_use_top_left"),_SCS("is_using_top_left")); +} + +CenterContainer::CenterContainer() { + + use_top_left=false; } diff --git a/scene/gui/center_container.h b/scene/gui/center_container.h index 458e2e7251..9cd9173fab 100644 --- a/scene/gui/center_container.h +++ b/scene/gui/center_container.h @@ -36,11 +36,16 @@ class CenterContainer : public Container { OBJ_TYPE( CenterContainer, Container ); + bool use_top_left; protected: void _notification(int p_what); + static void _bind_methods(); public: + void set_use_top_left(bool p_enable); + bool is_using_top_left() const; + virtual Size2 get_minimum_size() const; CenterContainer(); diff --git a/scene/gui/control.cpp b/scene/gui/control.cpp index 6878793360..fc24294a70 100644 --- a/scene/gui/control.cpp +++ b/scene/gui/control.cpp @@ -1738,9 +1738,9 @@ float Control::_a2s(float p_val, AnchorType p_anchor,float p_range) const { case ANCHOR_RATIO: { return Math::floor(p_range*p_val); } break; - case ANCHOR_CENTER: { - return Math::floor((p_range/2)-p_val); - } break; + case ANCHOR_CENTER: { + return Math::floor((p_range/2)-p_val); + } break; } return 0; } diff --git a/scene/gui/control.h b/scene/gui/control.h index f9225a1c2b..64b5a9b661 100644 --- a/scene/gui/control.h +++ b/scene/gui/control.h @@ -55,7 +55,7 @@ public: ANCHOR_BEGIN, ANCHOR_END, ANCHOR_RATIO, - ANCHOR_CENTER, + ANCHOR_CENTER, }; enum FocusMode { |