X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Fdevel-api%2Fcontrols%2Fcontrol-devel.cpp;h=5c940177eb713d22051e4b4b38b59cbe64a2017a;hb=26efc210fc636e51a4d3df9ae7fbcc1d2a8bac40;hp=01f240fc69d611681b6ccb58795a3f484331d01d;hpb=6535b9ab0980c20e31c8ad6af7b3439e97954682;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 01f240f..5c94017 100755 --- a/dali-toolkit/devel-api/controls/control-devel.cpp +++ b/dali-toolkit/devel-api/controls/control-devel.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018 Samsung Electronics Co., Ltd. + * Copyright (c) 2019 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. @@ -22,7 +22,9 @@ #include // INTERNAL INCLUDES +#include #include +#include #include #include @@ -110,47 +112,221 @@ void SetInputMethodContext( Internal::Control& control, InputMethodContext& inpu Internal::Control::Impl::Get( control ).SetInputMethodContext( inputMethodContext ); } -Toolkit::LayoutItem GetLayout( Control control ) +VisualEventSignalType& VisualEventSignal( Control control ) { - const Internal::Control& internalControl = Toolkit::Internal::GetImplementation( control ); - const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( internalControl ); - return Toolkit::LayoutItem( controlDataImpl.GetLayout().Get() ); + Internal::Control& internalControl = Toolkit::Internal::GetImplementation( control ); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( internalControl ); + return controlDataImpl.VisualEventSignal(); } -Toolkit::LayoutItem GetLayout( Internal::Control& control ) +static Toolkit::Internal::Control::Impl *GetControlImplementationIfAny( Dali::Actor actor) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - return Toolkit::LayoutItem( controlDataImpl.GetLayout().Get() ); + Dali::Toolkit::Control c = Toolkit::Control::DownCast( actor ); + if ( c ) + { + auto &impl1 = Toolkit::Internal::GetImplementation( c ); + auto &impl2 = Toolkit::Internal::Control::Impl::Get( impl1 ); + return &impl2; + } + return nullptr; } -void SetLayout( Internal::Control& control, Toolkit::LayoutItem layout ) +Toolkit::Control::AccessibilityActivateSignalType &AccessibilityActivateSignal( Toolkit::Control control ) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - controlDataImpl.SetLayout( GetImplementation( layout ) ); + auto ac = GetControlImplementationIfAny ( control ); + return ac->mAccessibilityActivateSignal; } -void SetLayout( Control control, Toolkit::LayoutItem layout ) +Toolkit::Control::AccessibilityReadingSkippedSignalType &AccessibilityReadingSkippedSignal( Toolkit::Control control ) { - Internal::Control& internalControl = Toolkit::Internal::GetImplementation( control ); - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( internalControl ); - if( layout ) + auto ac = GetControlImplementationIfAny ( control ); + return ac->mAccessibilityReadingSkippedSignal; +} + +Toolkit::Control::AccessibilityReadingCancelledSignalType &AccessibilityReadingCancelledSignal( Toolkit::Control control ) +{ + auto ac = GetControlImplementationIfAny ( control ); + return ac->mAccessibilityReadingCancelledSignal; +} + +Toolkit::Control::AccessibilityReadingStoppedSignalType &AccessibilityReadingStoppedSignal( Toolkit::Control control ) +{ + auto ac = GetControlImplementationIfAny ( control ); + return ac->mAccessibilityReadingStoppedSignal; +} + +Toolkit::Control::AccessibilityGetNameSignalType &AccessibilityGetNameSignal( Toolkit::Control control ) +{ + auto ac = GetControlImplementationIfAny ( control ); + return ac->mAccessibilityGetNameSignal; +} + +Toolkit::Control::AccessibilityGetDescriptionSignalType &AccessibilityGetDescriptionSignal( Toolkit::Control control ) +{ + auto ac = GetControlImplementationIfAny ( control ); + return ac->mAccessibilityGetDescriptionSignal; +} + +Toolkit::Control::AccessibilityDoGestureSignalType &AccessibilityDoGestureSignal( Toolkit::Control control ) +{ + auto ac = GetControlImplementationIfAny ( control ); + return ac->mAccessibilityDoGestureSignal; +} + +void AppendAccessibilityRelation( Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) { - controlDataImpl.SetLayout( GetImplementation( layout ) ); + auto index = static_cast(relation); + if (index >= ac->mAccessibilityRelations.size()) + { + DALI_LOG_INFO( gLogFilter, Debug::Verbose, "Relation index exceeds vector size." ); + return; + } + + auto obj = ac->GetAccessibilityObject(destination); + ac->mAccessibilityRelations[index].push_back(obj->GetAddress()); } - else +} + +void RemoveAccessibilityRelation( Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) { - controlDataImpl.RemoveLayout(); + auto index = static_cast(relation); + if (index >= ac->mAccessibilityRelations.size()) + { + DALI_LOG_INFO( gLogFilter, Debug::Verbose, "Relation index exceeds vector size." ); + return; + } + + auto obj = ac->GetAccessibilityObject(destination); + 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); + } + } } } -void RequestLayout( Internal::Control& control ) +std::vector> GetAccessibilityRelations( Dali::Actor control ) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - Toolkit::Internal::LayoutItemPtr layoutItem = controlDataImpl.GetLayout(); - if ( layoutItem ) + if ( auto ac = GetControlImplementationIfAny ( control ) ) { - layoutItem->RequestLayout(); + return ac->mAccessibilityRelations; } + return {}; +} + +void ClearAccessibilityRelations( Dali::Actor control ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + for (auto &it : ac->mAccessibilityRelations) + it.clear(); + } +} + +void SetAccessibilityConstructor( Dali::Actor control, + std::function< std::unique_ptr< Dali::Accessibility::Accessible >( Dali::Actor ) > constructor ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + ac->accessibilityConstructor = constructor; + } +} + +void AppendAccessibilityAttribute( Dali::Actor control, const std::string& key, + const std::string value ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + ac->AppendAccessibilityAttribute( key, value ); + } +} + +void RemoveAccessibilityAttribute( Dali::Actor control, const std::string& key ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + ac->RemoveAccessibilityAttribute( key ); + } +} + +void ClearAccessibilityAttributes( Dali::Actor control ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + ac->ClearAccessibilityAttributes(); + } +} + +void SetAccessibilityReadingInfoType( Dali::Actor control, const Dali::Accessibility::ReadingInfoTypes types ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + ac->SetAccessibilityReadingInfoType( types ); + } +} + +Dali::Accessibility::ReadingInfoTypes GetAccessibilityReadingInfoType(Dali::Actor control ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + return ac->GetAccessibilityReadingInfoType(); + } + return {}; +} + +bool ClearAccessibilityHighlight( Dali::Actor control ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + auto ptr = dynamic_cast( ac ); + if( ptr ) + return ptr->ClearHighlight(); + } + return false; +} + +bool GrabAccessibilityHighlight( Dali::Actor control ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + auto ptr = dynamic_cast( ac ); + if( ptr ) + return ptr->GrabHighlight(); + } + return false; +} + +Dali::Accessibility::States GetAccessibilityStates( Dali::Actor control ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + auto ptr = dynamic_cast( ac ); + if(ptr) + return ptr->GetStates(); + } + return {}; +} + +void NotifyAccessibilityStateChange( Dali::Actor control, Dali::Accessibility::States states, bool doRecursive ) +{ + if ( auto ac = GetControlImplementationIfAny ( control ) ) + { + ac->GetAccessibilityObject()->NotifyAccessibilityStateChange( states, doRecursive ); + } +} + +Dali::Accessibility::Accessible *GetBoundAccessibilityObject( Dali::Actor control ) +{ + return Dali::Accessibility::Accessible::Get( control ); } } // namespace DevelControl