X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Fdevel-api%2Fcontrols%2Fcontrol-devel.cpp;h=55becb36f3bb271f56dd36a9e2933410e171e117;hb=460a840fa3c43160f3ca3679099c38985cca5cc5;hp=04b13d31a67c02738d38319976c3ddeb09e2d3da;hpb=c684d99e0c75210ab867c48f080e4a1cf0b46781;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 old mode 100755 new mode 100644 index 04b13d3..55becb3 --- a/dali-toolkit/devel-api/controls/control-devel.cpp +++ b/dali-toolkit/devel-api/controls/control-devel.cpp @@ -1,5 +1,5 @@ /* - * Copyright (c) 2019 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. @@ -19,102 +19,348 @@ #include "control-devel.h" // EXTERNAL INCLUDES +#include #include // INTERNAL INCLUDES +#include #include #include -#include +#include namespace Dali { - namespace Toolkit { - namespace DevelControl { +void RegisterVisual(Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual) +{ + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + controlDataImpl.RegisterVisual(index, visual); +} -void RegisterVisual( Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual ) +void RegisterVisual(Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, int depthIndex) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - controlDataImpl.RegisterVisual( index, visual ); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + controlDataImpl.RegisterVisual(index, visual, depthIndex); } -void RegisterVisual( Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, int depthIndex ) +void RegisterVisual(Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, bool enabled) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - controlDataImpl.RegisterVisual( index, visual, depthIndex ); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + controlDataImpl.RegisterVisual(index, visual, enabled); } -void RegisterVisual( Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, bool enabled ) +void RegisterVisual(Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, bool enabled, int depthIndex) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - controlDataImpl.RegisterVisual( index, visual, enabled ); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + controlDataImpl.RegisterVisual(index, visual, enabled, depthIndex); } -void RegisterVisual( Internal::Control& control, Dali::Property::Index index, Toolkit::Visual::Base& visual, bool enabled, int depthIndex ) +void UnregisterVisual(Internal::Control& control, Dali::Property::Index index) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - controlDataImpl.RegisterVisual( index, visual, enabled, depthIndex ); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + controlDataImpl.UnregisterVisual(index); } -void UnregisterVisual( Internal::Control& control, Dali::Property::Index index ) +Toolkit::Visual::Base GetVisual(const Internal::Control& control, Dali::Property::Index index) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - controlDataImpl.UnregisterVisual( index ); + const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + return controlDataImpl.GetVisual(index); } -Toolkit::Visual::Base GetVisual( const Internal::Control& control, Dali::Property::Index index ) +void EnableVisual(Internal::Control& control, Dali::Property::Index index, bool enable) { - const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - return controlDataImpl.GetVisual( index ); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + controlDataImpl.EnableVisual(index, enable); } -void EnableVisual( Internal::Control& control, Dali::Property::Index index, bool enable ) +bool IsVisualEnabled(const Internal::Control& control, Dali::Property::Index index) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - controlDataImpl.EnableVisual( index, enable ); + const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + return controlDataImpl.IsVisualEnabled(index); } -bool IsVisualEnabled( const Internal::Control& control, Dali::Property::Index index ) +Dali::Animation CreateTransition(Internal::Control& control, const Toolkit::TransitionData& handle) { - const Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - return controlDataImpl.IsVisualEnabled( index ); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + return controlDataImpl.CreateTransition(handle); } -Dali::Animation CreateTransition( Internal::Control& control, const Toolkit::TransitionData& handle ) +void AddTransitions(Internal::Control& control, + Dali::Animation animation, + const Toolkit::TransitionData& transitionData) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - return controlDataImpl.CreateTransition( handle ); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(control); + controlDataImpl.AddTransitions(animation, transitionData); } +void DoAction(Control& control, Dali::Property::Index visualIndex, Dali::Property::Index actionId, const Dali::Property::Value attributes) +{ + Internal::Control& controlInternal = Toolkit::Internal::GetImplementation(control); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(controlInternal); + controlDataImpl.DoAction(visualIndex, actionId, attributes); +} -void AddTransitions( Internal::Control& control, - Dali::Animation animation, - const Toolkit::TransitionData& transitionData ) +void SetInputMethodContext(Internal::Control& control, InputMethodContext& inputMethodContext) { - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( control ); - controlDataImpl.AddTransitions( animation, transitionData ); + Internal::Control::Impl::Get(control).SetInputMethodContext(inputMethodContext); } -void DoAction( Control& control, Dali::Property::Index visualIndex, Dali::Property::Index actionId, const Dali::Property::Value attributes ) +VisualEventSignalType& VisualEventSignal(Control control) { - Internal::Control& controlInternal = Toolkit::Internal::GetImplementation( control ); - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( controlInternal ); - controlDataImpl.DoAction( visualIndex, actionId, attributes ); + Internal::Control& internalControl = Toolkit::Internal::GetImplementation(control); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(internalControl); + return controlDataImpl.VisualEventSignal(); } -void SetInputMethodContext( Internal::Control& control, InputMethodContext& inputMethodContext ) +Dali::Property GetVisualProperty(Control control, Dali::Property::Index index, Dali::Property::Key visualPropertyKey) { - Internal::Control::Impl::Get( control ).SetInputMethodContext( inputMethodContext ); + Internal::Control& internalControl = Toolkit::Internal::GetImplementation(control); + Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get(internalControl); + return controlDataImpl.GetVisualProperty(index, visualPropertyKey); } -VisualEventSignalType& VisualEventSignal( Control control ) +void CreateTransitions(Control control, Dali::Animation& animation, Dali::Toolkit::Control source, AlphaFunction alphaFunction, TimePeriod timePeriod) { - Internal::Control& internalControl = Toolkit::Internal::GetImplementation( control ); - Internal::Control::Impl& controlDataImpl = Internal::Control::Impl::Get( internalControl ); - return controlDataImpl.VisualEventSignal(); + 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); + if(control) + { + auto& internalControl = Toolkit::Internal::GetImplementation(control); + auto& controlDataImpl = Toolkit::Internal::Control::Impl::Get(internalControl); + return &controlDataImpl; + } + return nullptr; +} + +Toolkit::DevelControl::AccessibilityActivateSignalType& AccessibilityActivateSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityActivateSignal; +} + +Toolkit::DevelControl::AccessibilityReadingSkippedSignalType& AccessibilityReadingSkippedSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityReadingSkippedSignal; +} + +Toolkit::DevelControl::AccessibilityReadingPausedSignalType& AccessibilityReadingPausedSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityReadingPausedSignal; +} + +Toolkit::DevelControl::AccessibilityReadingResumedSignalType& AccessibilityReadingResumedSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityReadingResumedSignal; +} + +Toolkit::DevelControl::AccessibilityReadingCancelledSignalType& AccessibilityReadingCancelledSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityReadingCancelledSignal; +} + +Toolkit::DevelControl::AccessibilityReadingStoppedSignalType& AccessibilityReadingStoppedSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityReadingStoppedSignal; +} + +Toolkit::DevelControl::AccessibilityGetNameSignalType& AccessibilityGetNameSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityGetNameSignal; +} + +Toolkit::DevelControl::AccessibilityGetDescriptionSignalType& AccessibilityGetDescriptionSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityGetDescriptionSignal; +} + +Toolkit::DevelControl::AccessibilityDoGestureSignalType& AccessibilityDoGestureSignal(Toolkit::Control control) +{ + return GetControlImplementation(control)->mAccessibilityDoGestureSignal; +} + +void AppendAccessibilityRelation(Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation) +{ + 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()); + } + } +} + +void RemoveAccessibilityRelation(Dali::Actor control, Actor destination, Dali::Accessibility::RelationType relation) +{ + 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) + { + return; + } + + auto address = object->GetAddress(); + + auto& targets = controlDataImpl->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) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + return controlDataImpl->mAccessibilityRelations; + } + return {}; +} + +void ClearAccessibilityRelations(Dali::Actor control) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + for(auto& it : controlDataImpl->mAccessibilityRelations) + { + it.clear(); + } + } +} + +void SetAccessibilityConstructor(Dali::Actor control, std::function(Dali::Actor)> constructor) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + controlDataImpl->mAccessibilityConstructor = constructor; + } +} + +void AppendAccessibilityAttribute(Dali::Actor control, const std::string& key, const std::string value) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + controlDataImpl->AppendAccessibilityAttribute(key, value); + } +} + +void RemoveAccessibilityAttribute(Dali::Actor control, const std::string& key) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + controlDataImpl->RemoveAccessibilityAttribute(key); + } +} + +void ClearAccessibilityAttributes(Dali::Actor control) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + controlDataImpl->ClearAccessibilityAttributes(); + } +} + +void SetAccessibilityReadingInfoType(Dali::Actor control, const Dali::Accessibility::ReadingInfoTypes types) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + controlDataImpl->SetAccessibilityReadingInfoType(types); + } +} + +Dali::Accessibility::ReadingInfoTypes GetAccessibilityReadingInfoType(Dali::Actor control) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + return controlDataImpl->GetAccessibilityReadingInfoType(); + } + return {}; +} + +bool ClearAccessibilityHighlight(Dali::Actor control) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + auto object = dynamic_cast(controlDataImpl->GetAccessibilityObject()); + if(object) + { + return object->ClearHighlight(); + } + } + return false; +} + +bool GrabAccessibilityHighlight(Dali::Actor control) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + auto object = dynamic_cast(controlDataImpl->GetAccessibilityObject()); + if(object) + { + return object->GrabHighlight(); + } + } + return false; +} + +Dali::Accessibility::States GetAccessibilityStates(Dali::Actor control) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + auto object = dynamic_cast(controlDataImpl->GetAccessibilityObject()); + if(object) + { + return object->GetStates(); + } + } + return {}; +} + +void NotifyAccessibilityStateChange(Dali::Actor control, Dali::Accessibility::States states, bool isRecursive) +{ + if(auto controlDataImpl = GetControlImplementation(control)) + { + controlDataImpl->GetAccessibilityObject()->NotifyAccessibilityStateChange(std::move(states), isRecursive); + } +} + +Dali::Accessibility::Accessible* GetBoundAccessibilityObject(Dali::Actor control) +{ + return Dali::Accessibility::Accessible::Get(control); } } // namespace DevelControl