X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fcontrols%2Fimage-view%2Fimage-view-impl.cpp;h=f49f82d70ec4b2316307afae6aa1cc2e445cdfe7;hp=513960f89b2b146f2738bca4083703913bc68853;hb=b22b9008628e11531fc1dfa0a9f8632061aee112;hpb=c87b2e1b8bde8db53067b24e191a1adf9deeb8db diff --git a/dali-toolkit/internal/controls/image-view/image-view-impl.cpp b/dali-toolkit/internal/controls/image-view/image-view-impl.cpp index 513960f..f49f82d 100644 --- a/dali-toolkit/internal/controls/image-view/image-view-impl.cpp +++ b/dali-toolkit/internal/controls/image-view/image-view-impl.cpp @@ -97,9 +97,6 @@ void ImageView::OnInitialize() return std::unique_ptr( new DevelControl::AccessibleImpl(actor, Dali::Accessibility::Role::IMAGE)); }); - - //Enable highightability - Self().SetProperty(Toolkit::DevelControl::Property::ACCESSIBILITY_HIGHLIGHTABLE, true); } void ImageView::SetImage(const Property::Map& map) @@ -287,6 +284,84 @@ void ImageView::OnRelayout(const Vector2& size, RelayoutContainer& container) } } +void ImageView::OnCreateTransitions(Dali::Animation& animation, Dali::Toolkit::Control source, AlphaFunction alphaFunction, TimePeriod timePeriod) +{ + Dali::Toolkit::ImageView destinationHandle = Toolkit::ImageView(GetOwner()); + Toolkit::Visual::Base destinationVisual = DevelControl::GetVisual(GetImplementation(destinationHandle), Toolkit::ImageView::Property::IMAGE); + Property::Map destinationMap; + + if(!destinationVisual) + { + return; + } + + destinationVisual.CreatePropertyMap(destinationMap); + + static auto findValue = [](const Property::Map& map, Property::Index index) -> Vector4 { + Property::Value* propertyValue = map.Find(index); + if(propertyValue) + { + return propertyValue->Get(); + } + return Vector4{}; + }; + + Vector4 sourceMixColor(0.0f, 0.0f, 0.0f, 0.0f); + Vector4 sourceCornerRadius(0.0f, 0.0f, 0.0f, 0.0f); + Vector4 destinationMixColor = findValue(destinationMap, Dali::Toolkit::Visual::Property::MIX_COLOR); + Vector4 destinationCornerRadius = findValue(destinationMap, Toolkit::DevelVisual::Property::CORNER_RADIUS); + + Dali::Toolkit::ImageView sourceHandle = Dali::Toolkit::ImageView::DownCast(source); + Toolkit::Visual::Base sourceVisual; + Property::Map sourceMap; + + if(sourceHandle) + { + sourceVisual = DevelControl::GetVisual(GetImplementation(sourceHandle), Toolkit::ImageView::Property::IMAGE); + } + + if(sourceVisual) + { + sourceVisual.CreatePropertyMap(sourceMap); + sourceMixColor = findValue(sourceMap, Dali::Toolkit::Visual::Property::MIX_COLOR); + sourceCornerRadius = findValue(sourceMap, Toolkit::DevelVisual::Property::CORNER_RADIUS); + } + + std::vector properties; + std::vector> values; + + if(Vector3(sourceMixColor) != Vector3(destinationMixColor)) + { + properties.push_back(DevelControl::GetVisualProperty(destinationHandle, Toolkit::ImageView::Property::IMAGE, Toolkit::Visual::Property::MIX_COLOR)); + values.push_back(std::make_pair(Vector3(sourceMixColor), Vector3(destinationMixColor))); + } + if(std::abs(sourceMixColor.a - destinationMixColor.a) > Math::MACHINE_EPSILON_1) + { + properties.push_back(DevelControl::GetVisualProperty(destinationHandle, Toolkit::ImageView::Property::IMAGE, Toolkit::Visual::Property::OPACITY)); + values.push_back(std::make_pair(sourceMixColor.a, destinationMixColor.a)); + } + if(sourceCornerRadius != destinationCornerRadius) + { + properties.push_back(DevelControl::GetVisualProperty(destinationHandle, Toolkit::ImageView::Property::IMAGE, Toolkit::DevelVisual::Property::CORNER_RADIUS)); + values.push_back(std::make_pair(sourceCornerRadius, destinationCornerRadius)); + } + + for(uint32_t i = 0; i < properties.size(); ++i) + { + if(timePeriod.delaySeconds > 0.0f) + { + Dali::KeyFrames initialKeyframes = Dali::KeyFrames::New(); + initialKeyframes.Add(0.0f, values[i].first); + initialKeyframes.Add(1.0f, values[i].first); + animation.AnimateBetween(properties[i], initialKeyframes, TimePeriod(timePeriod.delaySeconds)); + } + Dali::KeyFrames keyframes = Dali::KeyFrames::New(); + keyframes.Add(0.0f, values[i].first); + keyframes.Add(1.0f, values[i].second); + animation.AnimateBetween(properties[i], keyframes, alphaFunction, timePeriod); + } +} + void ImageView::OnResourceReady(Toolkit::Control control) { // Visual ready so update visual attached to this ImageView, following call to RelayoutRequest will use this visual.