X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;ds=sidebyside;f=dali-toolkit%2Fdevel-api%2Fcontrols%2Fcontrol-devel.cpp;h=487aa1b159ec5496a290d493e5c669fe1f692770;hb=6ae6f36998b3be4efa1114e2df856e51628bf812;hp=0670e68667ba7f02d2ed6f65bd6be5f6ce71689b;hpb=bd126b5d480c08bf7a995b2c4532e80e76ec4ad2;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/devel-api/controls/control-devel.cpp b/dali-toolkit/devel-api/controls/control-devel.cpp index 0670e68..487aa1b 100644 --- a/dali-toolkit/devel-api/controls/control-devel.cpp +++ b/dali-toolkit/devel-api/controls/control-devel.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2020 Samsung Electronics Co., Ltd. + * Copyright (c) 2021 Samsung Electronics Co., Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -25,8 +25,8 @@ // INTERNAL INCLUDES #include #include -#include #include +#include namespace Dali { @@ -122,230 +122,243 @@ Dali::Property GetVisualProperty(Control control, Dali::Property::Index index, D return controlDataImpl.GetVisualProperty(index, visualPropertyKey); } -static Toolkit::Internal::Control::Impl *GetControlImplementationIfAny( Dali::Actor actor) +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* GetControlImplementationIfAny(Dali::Actor actor) { - Dali::Toolkit::Control c = Toolkit::Control::DownCast( actor ); - if ( c ) + Dali::Toolkit::Control c = Toolkit::Control::DownCast(actor); + if(c) { - auto &impl1 = Toolkit::Internal::GetImplementation( c ); - auto &impl2 = Toolkit::Internal::Control::Impl::Get( impl1 ); + auto& impl1 = Toolkit::Internal::GetImplementation(c); + auto& impl2 = Toolkit::Internal::Control::Impl::Get(impl1); return &impl2; } return nullptr; } -Toolkit::DevelControl::AccessibilityActivateSignalType &AccessibilityActivateSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityActivateSignalType& AccessibilityActivateSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityActivateSignal; } -Toolkit::DevelControl::AccessibilityReadingSkippedSignalType &AccessibilityReadingSkippedSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityReadingSkippedSignalType& AccessibilityReadingSkippedSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityReadingSkippedSignal; } -Toolkit::DevelControl::AccessibilityReadingPausedSignalType &AccessibilityReadingPausedSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityReadingPausedSignalType& AccessibilityReadingPausedSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityReadingPausedSignal; } -Toolkit::DevelControl::AccessibilityReadingResumedSignalType &AccessibilityReadingResumedSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityReadingResumedSignalType& AccessibilityReadingResumedSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityReadingResumedSignal; } -Toolkit::DevelControl::AccessibilityReadingCancelledSignalType &AccessibilityReadingCancelledSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityReadingCancelledSignalType& AccessibilityReadingCancelledSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityReadingCancelledSignal; } -Toolkit::DevelControl::AccessibilityReadingStoppedSignalType &AccessibilityReadingStoppedSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityReadingStoppedSignalType& AccessibilityReadingStoppedSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityReadingStoppedSignal; } -Toolkit::DevelControl::AccessibilityGetNameSignalType &AccessibilityGetNameSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityGetNameSignalType& AccessibilityGetNameSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityGetNameSignal; } -Toolkit::DevelControl::AccessibilityGetDescriptionSignalType &AccessibilityGetDescriptionSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityGetDescriptionSignalType& AccessibilityGetDescriptionSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityGetDescriptionSignal; } -Toolkit::DevelControl::AccessibilityDoGestureSignalType &AccessibilityDoGestureSignal( Toolkit::Control control ) +Toolkit::DevelControl::AccessibilityDoGestureSignalType& AccessibilityDoGestureSignal(Toolkit::Control control) { - auto ac = GetControlImplementationIfAny ( control ); + auto ac = GetControlImplementationIfAny(control); return ac->mAccessibilityDoGestureSignal; } -void AppendAccessibilityRelation( Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation) +void AppendAccessibilityRelation(Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { auto index = static_cast(relation); - if (index >= ac->mAccessibilityRelations.size()) + if(index >= ac->mAccessibilityRelations.size()) { - DALI_LOG_ERROR( "Relation index exceeds vector size." ); - return; + DALI_LOG_ERROR("Relation index exceeds vector size."); + return; } auto obj = ac->GetAccessibilityObject(destination); - if (obj) + if(obj) ac->mAccessibilityRelations[index].push_back(obj->GetAddress()); } } -void RemoveAccessibilityRelation( Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation) +void RemoveAccessibilityRelation(Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { auto index = static_cast(relation); - if (index >= ac->mAccessibilityRelations.size()) + if(index >= ac->mAccessibilityRelations.size()) { - DALI_LOG_ERROR( "Relation index exceeds vector size." ); - return; + DALI_LOG_ERROR("Relation index exceeds vector size."); + return; } auto obj = ac->GetAccessibilityObject(destination); - if (!obj) + if(!obj) return; auto address = obj->GetAddress(); - auto &targets = ac->mAccessibilityRelations[index]; - for (auto i = 0u; i < targets.size(); ++i) { - if (targets[i].ToString() == address.ToString()) - { - targets[i] = targets.back(); - targets.erase(targets.end() - 1); - } + auto& targets = ac->mAccessibilityRelations[index]; + for(auto i = 0u; i < targets.size(); ++i) + { + if(targets[i].ToString() == address.ToString()) + { + targets[i] = targets.back(); + targets.erase(targets.end() - 1); + } } } } -std::vector> GetAccessibilityRelations( Dali::Actor control ) +std::vector> GetAccessibilityRelations(Dali::Actor control) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { return ac->mAccessibilityRelations; } return {}; } -void ClearAccessibilityRelations( Dali::Actor control ) +void ClearAccessibilityRelations(Dali::Actor control) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { - for (auto &it : ac->mAccessibilityRelations) + for(auto& it : ac->mAccessibilityRelations) it.clear(); } } -void SetAccessibilityConstructor( Dali::Actor control, - std::function< std::unique_ptr< Dali::Accessibility::Accessible >( Dali::Actor ) > constructor ) +void SetAccessibilityConstructor(Dali::Actor control, + std::function(Dali::Actor)> constructor) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { ac->accessibilityConstructor = constructor; } } -void AppendAccessibilityAttribute( Dali::Actor control, const std::string& key, - const std::string value ) +void AppendAccessibilityAttribute(Dali::Actor control, const std::string& key, const std::string value) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { - ac->AppendAccessibilityAttribute( key, value ); + ac->AppendAccessibilityAttribute(key, value); } } -void RemoveAccessibilityAttribute( Dali::Actor control, const std::string& key ) +void RemoveAccessibilityAttribute(Dali::Actor control, const std::string& key) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { - ac->RemoveAccessibilityAttribute( key ); + ac->RemoveAccessibilityAttribute(key); } } -void ClearAccessibilityAttributes( Dali::Actor control ) +void ClearAccessibilityAttributes(Dali::Actor control) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { ac->ClearAccessibilityAttributes(); } } -void SetAccessibilityReadingInfoType( Dali::Actor control, const Dali::Accessibility::ReadingInfoTypes types ) +void SetAccessibilityReadingInfoType(Dali::Actor control, const Dali::Accessibility::ReadingInfoTypes types) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { - ac->SetAccessibilityReadingInfoType( types ); + ac->SetAccessibilityReadingInfoType(types); } } -Dali::Accessibility::ReadingInfoTypes GetAccessibilityReadingInfoType(Dali::Actor control ) +Dali::Accessibility::ReadingInfoTypes GetAccessibilityReadingInfoType(Dali::Actor control) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { return ac->GetAccessibilityReadingInfoType(); } return {}; } -bool ClearAccessibilityHighlight( Dali::Actor control ) +bool ClearAccessibilityHighlight(Dali::Actor control) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { - auto ptr = dynamic_cast( ac->GetAccessibilityObject() ); - if( ptr ) + auto ptr = dynamic_cast(ac->GetAccessibilityObject()); + if(ptr) return ptr->ClearHighlight(); } return false; } -bool GrabAccessibilityHighlight( Dali::Actor control ) +bool GrabAccessibilityHighlight(Dali::Actor control) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { - auto ptr = dynamic_cast( ac->GetAccessibilityObject() ); - if( ptr ) + auto ptr = dynamic_cast(ac->GetAccessibilityObject()); + if(ptr) return ptr->GrabHighlight(); } return false; } -Dali::Accessibility::States GetAccessibilityStates( Dali::Actor control ) +Dali::Accessibility::States GetAccessibilityStates(Dali::Actor control) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { - auto ptr = dynamic_cast( ac->GetAccessibilityObject() ); + auto ptr = dynamic_cast(ac->GetAccessibilityObject()); if(ptr) return ptr->GetStates(); } return {}; } -void NotifyAccessibilityStateChange( Dali::Actor control, Dali::Accessibility::States states, bool doRecursive ) +void NotifyAccessibilityStateChange(Dali::Actor control, Dali::Accessibility::States states, bool doRecursive) { - if ( auto ac = GetControlImplementationIfAny ( control ) ) + if(auto ac = GetControlImplementationIfAny(control)) { - ac->GetAccessibilityObject()->NotifyAccessibilityStateChange( std::move(states), doRecursive ); + ac->GetAccessibilityObject()->NotifyAccessibilityStateChange(std::move(states), doRecursive); } } -Dali::Accessibility::Accessible *GetBoundAccessibilityObject( Dali::Actor control ) +Dali::Accessibility::Accessible* GetBoundAccessibilityObject(Dali::Actor control) { - return Dali::Accessibility::Accessible::Get( control ); + return Dali::Accessibility::Accessible::Get(control); } } // namespace DevelControl