X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Fdevel-api%2Fcontrols%2Fcontrol-devel.cpp;h=7b497c9801571854d249a85757de241ad6739811;hp=55becb36f3bb271f56dd36a9e2933410e171e117;hb=06e51bb1b127122783024601956ccf7188144e4b;hpb=e8956b0df337f506154812b298eb5407a65711b2 diff --git a/dali-toolkit/devel-api/controls/control-devel.cpp b/dali-toolkit/devel-api/controls/control-devel.cpp index 55becb3..7b497c9 100644 --- a/dali-toolkit/devel-api/controls/control-devel.cpp +++ b/dali-toolkit/devel-api/controls/control-devel.cpp @@ -122,19 +122,6 @@ Dali::Property GetVisualProperty(Control control, Dali::Property::Index index, D return controlDataImpl.GetVisualProperty(index, visualPropertyKey); } -void CreateTransitions(Control control, Dali::Animation& animation, Dali::Toolkit::Control source, AlphaFunction alphaFunction, TimePeriod timePeriod) -{ - if(animation) - { - // make visual transition of control visual. - Internal::Control& internalControl = Toolkit::Internal::GetImplementation(control); - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(internalControl); - controlDataImpl.MakeVisualTransition(animation, source, Toolkit::Control::Property::BACKGROUND, alphaFunction, timePeriod); - controlDataImpl.MakeVisualTransition(animation, source, Toolkit::DevelControl::Property::SHADOW, alphaFunction, timePeriod); - internalControl.OnCreateTransitions(animation, source, alphaFunction, timePeriod); - } -} - static Toolkit::Internal::Control::Impl* GetControlImplementation(Dali::Actor actor) { Dali::Toolkit::Control control = Toolkit::Control::DownCast(actor); @@ -196,17 +183,10 @@ void AppendAccessibilityRelation(Dali::Actor control, Actor destination, Dali::A { if(auto controlDataImpl = GetControlImplementation(control)) { - auto index = static_cast(relation); - if(index >= controlDataImpl->mAccessibilityRelations.size()) - { - DALI_LOG_ERROR("Relation index exceeds vector size."); - return; - } - auto object = controlDataImpl->GetAccessibilityObject(destination); if(object) { - controlDataImpl->mAccessibilityRelations[index].push_back(object->GetAddress()); + controlDataImpl->mAccessibilityRelations[relation].insert(object); } } } @@ -215,28 +195,16 @@ void RemoveAccessibilityRelation(Dali::Actor control, Actor destination, Dali::A { if(auto controlDataImpl = GetControlImplementation(control)) { - auto index = static_cast(relation); - if(index >= controlDataImpl->mAccessibilityRelations.size()) - { - DALI_LOG_ERROR("Relation index exceeds vector size."); - return; - } - auto object = controlDataImpl->GetAccessibilityObject(destination); - if(!object) + if(object) { - return; - } + auto& relations = controlDataImpl->mAccessibilityRelations; - auto address = object->GetAddress(); + relations[relation].erase(object); - auto& targets = controlDataImpl->mAccessibilityRelations[index]; - for(auto i = 0u; i < targets.size(); ++i) - { - if(targets[i].ToString() == address.ToString()) + if(relations[relation].empty()) { - targets[i] = targets.back(); - targets.erase(targets.end() - 1); + relations.erase(relation); } } } @@ -246,8 +214,22 @@ std::vector> GetAccessibilityRelations(Dali: { if(auto controlDataImpl = GetControlImplementation(control)) { - return controlDataImpl->mAccessibilityRelations; + std::vector> result(static_cast(Accessibility::RelationType::MAX_COUNT)); + + // Map every Accessible* to its Address + for(auto& relation : controlDataImpl->mAccessibilityRelations) + { + auto index = static_cast(relation.first); + auto& targets = relation.second; + + std::transform(targets.begin(), targets.end(), std::back_inserter(result[index]), [](auto* x) { + return x->GetAddress(); + }); + } + + return result; } + return {}; } @@ -255,10 +237,7 @@ void ClearAccessibilityRelations(Dali::Actor control) { if(auto controlDataImpl = GetControlImplementation(control)) { - for(auto& it : controlDataImpl->mAccessibilityRelations) - { - it.clear(); - } + controlDataImpl->mAccessibilityRelations.clear(); } }