[Tizen] Adds transition effect 55/256855/1
authorSeungho Baek <sbsh.baek@samsung.com>
Tue, 29 Dec 2020 10:16:31 +0000 (19:16 +0900)
committerseungho <sbsh.baek@samsung.com>
Wed, 14 Apr 2021 03:47:03 +0000 (12:47 +0900)
Change-Id: Ieb2114227b69cfd1fcbbe97930f21bf902e3b2d8
Signed-off-by: Seungho Baek <sbsh.baek@samsung.com>
24 files changed:
automated-tests/src/dali/dali-test-suite-utils/test-custom-actor.cpp
automated-tests/src/dali/dali-test-suite-utils/test-custom-actor.h
automated-tests/src/dali/utc-Dali-Actor.cpp
automated-tests/src/dali/utc-Dali-CustomActor.cpp
automated-tests/src/dali/utc-Dali-Processors.cpp
dali/devel-api/actors/actor-devel.cpp
dali/devel-api/actors/actor-devel.h
dali/integration-api/core.cpp
dali/integration-api/core.h
dali/integration-api/processor-interface.h
dali/internal/common/core-impl.cpp
dali/internal/common/core-impl.h
dali/internal/event/actors/actor-impl.cpp
dali/internal/event/actors/actor-impl.h
dali/internal/event/actors/actor-parent-impl.cpp
dali/internal/event/actors/actor-parent-impl.h
dali/internal/event/actors/actor-property-handler.cpp
dali/internal/event/actors/custom-actor-internal.h
dali/internal/update/nodes/node.cpp
dali/internal/update/nodes/node.h
dali/internal/update/rendering/scene-graph-renderer.cpp
dali/public-api/actors/custom-actor-impl.cpp
dali/public-api/actors/custom-actor-impl.h
dali/public-api/file.list

index e4f10994978510831deade35108a34a194fd3cea..87c141a40abccca8f641f1d29dd6c894857245ce 100644 (file)
@@ -204,6 +204,16 @@ uint32_t TestCustomActor::GetDepth()
   return GetImpl().mDepth;
 }
 
+void TestCustomActor::SetTransparent(bool transparent)
+{
+  return GetImpl().SetTransparent(transparent);
+}
+
+bool TestCustomActor::GetTransparent()
+{
+  return GetImpl().GetTransparent();
+}
+
 TestCustomActor::TestCustomActor()
 {
 }
@@ -386,6 +396,16 @@ bool TestCustomActor::RelayoutDependentOnChildren(Dimension::Type dimension)
   return false;
 }
 
+void TestCustomActor::SetTransparent(bool transparent)
+{
+  CustomActorImpl::SetTransparent(transparent);
+}
+
+bool TestCustomActor::GetTransparent() const
+{
+  return CustomActorImpl::GetTransparent();
+}
+
 void TestCustomActor::SetDaliProperty(std::string s)
 {
   Self().SetProperty(mDaliProperty, s);
index ed11c58fd8658ed71d33272989ec2d4627c4cdc0..83b1fd543e31116beffc0dac06cbaf836ac6ee2d 100644 (file)
@@ -2,7 +2,7 @@
 #define TEST_CUSTOM_ACTOR_H
 
 /*
- * 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.
@@ -89,6 +89,8 @@ public:
   float                     TestCalculateChildSizeBase(const Dali::Actor& child, Dali::Dimension::Type dimension);
   bool                      TestRelayoutDependentOnChildrenBase(Dali::Dimension::Type dimension);
   uint32_t                  GetDepth();
+  void                      SetTransparent(bool transparent);
+  bool                      GetTransparent();
 
 private:
   TestCustomActor(Impl::TestCustomActor& impl);
@@ -146,6 +148,8 @@ public:
   float                        CalculateChildSize(const Dali::Actor& child, Dali::Dimension::Type dimension) override;
   void                         OnLayoutNegotiated(float size, Dali::Dimension::Type dimension) override;
   bool                         RelayoutDependentOnChildren(Dali::Dimension::Type dimension = Dali::Dimension::ALL_DIMENSIONS) override;
+  void                         SetTransparent(bool transparent) override;
+  bool                         GetTransparent() const override;
   static void                  SetProperty(Dali::BaseObject* object, Dali::Property::Index index, const Dali::Property::Value& value);
   static Dali::Property::Value GetProperty(Dali::BaseObject* object, Dali::Property::Index index);
 
index 02324d3751310a0cef3abf39fd3a8a90a70bd35a..809f08f7358005e7749425b20d7f88159ca4cd35 100644 (file)
@@ -647,6 +647,75 @@ int UtcDaliActorRemoveP(void)
   END_TEST;
 }
 
+int UtcDaliActorSwitchParentP(void)
+{
+  tet_infoline("Testing Actor::UtcDaliActorSwitchParentP");
+  TestApplication application;
+
+  Actor parent1 = Actor::New();
+  Actor child   = Actor::New();
+
+  application.GetScene().Add(parent1);
+
+  DALI_TEST_EQUALS(parent1.GetChildCount(), 0u, TEST_LOCATION);
+
+  parent1.Add(child);
+
+  DALI_TEST_EQUALS(parent1.GetChildCount(), 1u, TEST_LOCATION);
+
+  Actor parent2 = Actor::New();
+  application.GetScene().Add(parent2);
+  DevelActor::SwitchParent(child, parent2);
+
+  DALI_TEST_EQUALS(parent1.GetChildCount(), 0u, TEST_LOCATION);
+  DALI_TEST_EQUALS(parent2.GetChildCount(), 1u, TEST_LOCATION);
+
+  END_TEST;
+}
+
+int UtcDaliActorSwitchParentN(void)
+{
+  tet_infoline("Testing Actor::UtcDaliActorSwitchParentN");
+  TestApplication application;
+
+  Actor parent1 = Actor::New();
+  Actor child   = Actor::New();
+
+  DALI_TEST_EQUALS(parent1.GetChildCount(), 0u, TEST_LOCATION);
+
+  parent1.Add(child);
+
+  DALI_TEST_EQUALS(parent1.GetChildCount(), 1u, TEST_LOCATION);
+
+  Actor parent2 = Actor::New();
+
+  // Try switch parent with that both of parent1 and parent2 are off scene.
+  try
+  {
+    DevelActor::SwitchParent(child, parent2);
+    tet_printf("Assertion test failed - no Exception\n");
+    tet_result(TET_FAIL);
+  }
+  catch(Dali::DaliException& e)
+  {
+    DALI_TEST_PRINT_ASSERT(e);
+    DALI_TEST_ASSERT(e, "parent", TEST_LOCATION);
+    DALI_TEST_EQUALS(parent1.GetChildCount(), 1u, TEST_LOCATION);
+    DALI_TEST_EQUALS(parent2.GetChildCount(), 0u, TEST_LOCATION);
+    application.GetScene().Add(parent1);
+    application.GetScene().Add(parent2);
+    DevelActor::SwitchParent(child, parent2);
+    DALI_TEST_EQUALS(parent1.GetChildCount(), 0u, TEST_LOCATION);
+    DALI_TEST_EQUALS(parent2.GetChildCount(), 1u, TEST_LOCATION);
+  }
+  catch(...)
+  {
+    tet_printf("Assertion test failed - wrong Exception\n");
+    tet_result(TET_FAIL);
+  }
+  END_TEST;
+}
+
 int UtcDaliActorGetChildCount(void)
 {
   TestApplication application;
index 208f5634c7a8ee58ee629ce627d15a5afd6f12d9..235b5a8444007ef0bd774f088ac30398a59b017d 100644 (file)
@@ -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.
@@ -1081,6 +1081,29 @@ int UtcDaliCustomActorCustomActor(void)
   END_TEST;
 }
 
+int UtcDaliCustomActorImplSetTransparent(void)
+{
+  TestApplication application; // Need the type registry
+
+  Test::TestCustomActor actor = Test::TestCustomActor::New();
+  application.GetScene().Add(actor);
+  actor.SetProperty(Actor::Property::OPACITY, 0.1f);
+  actor.SetProperty(Actor::Property::SIZE, Vector2(400, 400));
+
+  DALI_TEST_EQUALS(false, actor.GetTransparent(), TEST_LOCATION);
+
+  actor.SetTransparent(true);
+
+  // flush the queue and render once
+  application.SendNotification();
+  application.Render();
+
+  DALI_TEST_EQUALS(true, actor.GetTransparent(), TEST_LOCATION);
+
+  application.GetScene().Remove(actor);
+  END_TEST;
+}
+
 int UtcDaliCustomActorImplRelayoutRequest(void)
 {
   TestApplication application;
index 9f797fbe3f51b2074a903ed492e94d0ed78a51bd..0d1b864b6387bb9800aaa699c732fec6f1e29910 100644 (file)
@@ -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.
@@ -31,7 +31,7 @@ public:
   {
   }
 
-  virtual void Process()
+  virtual void Process(bool postProcessor)
   {
     processRun = true;
   }
@@ -113,5 +113,40 @@ int UtcDaliCoreProcessorMultipleP(void)
   DALI_TEST_CHECK(testProcessor2.processRun == false);
   DALI_TEST_CHECK(testProcessor3.processRun);
 
+  END_TEST;
+}
+
+int UtcDaliCorePostProcessorP(void)
+{
+  TestApplication application;
+
+  TestProcessor      testProcessor;
+  Integration::Core& core = application.GetCore();
+  core.RegisterProcessor(testProcessor, true);
+
+  tet_infoline("Test that the processor has not been executed yet:");
+  DALI_TEST_CHECK(testProcessor.processRun == false);
+
+  application.SendNotification();
+
+  tet_infoline("Test that the processor has been executed:");
+  DALI_TEST_CHECK(testProcessor.processRun);
+
+  // Clear down for next part of test
+  testProcessor.processRun = false;
+
+  core.UnregisterProcessor(testProcessor);
+  application.SendNotification();
+  tet_infoline("Test that the processor is still executed:");
+  DALI_TEST_CHECK(testProcessor.processRun);
+
+  // Clear down for next part of test
+  testProcessor.processRun = false;
+
+  core.UnregisterProcessor(testProcessor, true);
+  application.SendNotification();
+  tet_infoline("Test that the processor has not been executed again:");
+  DALI_TEST_CHECK(testProcessor.processRun == false);
+
   END_TEST;
 }
\ No newline at end of file
index fd0843467631674307cd72924c5b13985502463b..650fe92500bbdab4e14935032b007df73d8d5376 100755 (executable)
@@ -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.
@@ -53,6 +53,11 @@ Actor::TouchEventSignalType& InterceptTouchedSignal(Actor actor)
   return GetImplementation(actor).InterceptTouchedSignal();
 }
 
+void SwitchParent(Actor actor, Actor newParent)
+{
+  return GetImplementation(actor).SwitchParent(GetImplementation(newParent));
+}
+
 } // namespace DevelActor
 
 } // namespace Dali
index 5821af0a0866aa229abd23713def400c0013c134..33df9ab720fdcc5fa8054bdbb1a5dc0fa933ca25 100755 (executable)
@@ -2,7 +2,7 @@
 #define DALI_ACTOR_DEVEL_H
 
 /*
- * 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.
@@ -272,6 +272,14 @@ DALI_CORE_API ChildOrderChangedSignalType& ChildOrderChangedSignal(Actor actor);
  */
 DALI_CORE_API Actor::TouchEventSignalType& InterceptTouchedSignal(Actor actor);
 
+/**
+ * Switch parent in the same tree.
+ * Both of current parent Actor and new parent Actor must be added on Scene.
+ * If not, use Add() instead.
+ * This method don't emit any notification such as off scene, on scene, added or removed.
+ */
+DALI_CORE_API void SwitchParent(Actor actor, Actor newParent);
+
 } // namespace DevelActor
 
 } // namespace Dali
index 3942bea8c209c3c8e6a755c93a183ff523147365..99001f3a2914fa0767dade33349d8c840a0d774c 100644 (file)
@@ -130,14 +130,14 @@ void Core::PostRender(bool uploadOnly)
   mImpl->PostRender(uploadOnly);
 }
 
-void Core::RegisterProcessor(Processor& processor)
+void Core::RegisterProcessor(Processor& processor, bool postProcessor)
 {
-  mImpl->RegisterProcessor(processor);
+  mImpl->RegisterProcessor(processor, postProcessor);
 }
 
-void Core::UnregisterProcessor(Processor& processor)
+void Core::UnregisterProcessor(Processor& processor, bool postProcessor)
 {
-  mImpl->UnregisterProcessor(processor);
+  mImpl->UnregisterProcessor(processor, postProcessor);
 }
 
 ObjectRegistry Core::GetObjectRegistry() const
index 4952c578c538a5b5b8eef9b7e722922b707d09e1..1dd070df2f74beb69709d17dc4f393f0624729da 100644 (file)
@@ -392,14 +392,16 @@ public:
    *
    * Note, Core does not take ownership of this processor.
    * @param[in] processor The process to register
+   * @param[in] postProcessor set this processor required to be called after size negotiation. Default is false.
    */
-  void RegisterProcessor(Processor& processor);
+  void RegisterProcessor(Processor& processor, bool postProcessor = false);
 
   /**
    * @brief Unregister a processor
    * @param[in] processor The process to unregister
+   * @param[in] postProcessor True if the processor to be unregister is for post processor.
    */
-  void UnregisterProcessor(Processor& processor);
+  void UnregisterProcessor(Processor& processor, bool postProcessor = false);
 
   /**
    * @brief Gets the Object registry.
index 70c01bdcd91968aea6b36e43a33d9251dbf8ddcf..45408ff7044b736efcd3c1609e788451c6e39b61 100644 (file)
@@ -2,7 +2,7 @@
 #define DALI_INTEGRATION_PROCESSOR_INTERFACE_H
 
 /*
- * 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.
@@ -35,7 +35,7 @@ public:
   /**
    * @brief Run the processor
    */
-  virtual void Process() = 0;
+  virtual void Process(bool postProcessor = false) = 0;
 
 protected:
   /**
index 41adba0b2dbc07812d44024dbae84232c79aa376..6d129e6ad21d817c7407d1e18bf3bba706575fce 100644 (file)
@@ -297,6 +297,9 @@ void Core::ProcessEvents()
   // Run the size negotiation after event processing finished signal
   mRelayoutController->Relayout();
 
+  // Run any registered post processors
+  RunPostProcessors();
+
   // Rebuild depth tree after event processing has finished
   for(auto scene : scenes)
   {
@@ -328,17 +331,35 @@ uint32_t Core::GetMaximumUpdateCount() const
   return MAXIMUM_UPDATE_COUNT;
 }
 
-void Core::RegisterProcessor(Integration::Processor& processor)
+void Core::RegisterProcessor(Integration::Processor& processor, bool postProcessor)
 {
-  mProcessors.PushBack(&processor);
+  if(postProcessor)
+  {
+    mPostProcessors.PushBack(&processor);
+  }
+  else
+  {
+    mProcessors.PushBack(&processor);
+  }
 }
 
-void Core::UnregisterProcessor(Integration::Processor& processor)
+void Core::UnregisterProcessor(Integration::Processor& processor, bool postProcessor)
 {
-  auto iter = std::find(mProcessors.Begin(), mProcessors.End(), &processor);
-  if(iter != mProcessors.End())
+  if(postProcessor)
   {
-    mProcessors.Erase(iter);
+    auto iter = std::find(mPostProcessors.Begin(), mPostProcessors.End(), &processor);
+    if(iter != mPostProcessors.End())
+    {
+      mPostProcessors.Erase(iter);
+    }
+  }
+  else
+  {
+    auto iter = std::find(mProcessors.Begin(), mProcessors.End(), &processor);
+    if(iter != mProcessors.End())
+    {
+      mProcessors.Erase(iter);
+    }
   }
 }
 
@@ -351,7 +372,21 @@ void Core::RunProcessors()
   {
     if(processor)
     {
-      processor->Process();
+      processor->Process(false);
+    }
+  }
+}
+
+void Core::RunPostProcessors()
+{
+  // Copy processor pointers to prevent changes to vector affecting loop iterator.
+  Dali::Vector<Integration::Processor*> processors(mPostProcessors);
+
+  for(auto processor : processors)
+  {
+    if(processor)
+    {
+      processor->Process(true);
     }
   }
 }
index 3f0307d3d18b2c50ea2a42742e50ebc8bef1a5f7..9744d0dfccdc19bfe29e84bd8c66cdaadf2c2ad6 100644 (file)
@@ -175,12 +175,12 @@ public:
   /**
    * @copydoc Dali::Integration::Core::RegisterProcessor
    */
-  void RegisterProcessor(Dali::Integration::Processor& processor);
+  void RegisterProcessor(Integration::Processor& processor, bool postProcessor = false);
 
   /**
    * @copydoc Dali::Integration::Core::UnregisterProcessor
    */
-  void UnregisterProcessor(Dali::Integration::Processor& processor);
+  void UnregisterProcessor(Dali::Integration::Processor& processor, bool postProcessor = false);
 
   /**
    * @copydoc Dali::Internal::ThreadLocalStorage::AddScene()
@@ -245,6 +245,11 @@ private:
    */
   void RunProcessors();
 
+  /**
+   * Run each registered postprocessor
+   */
+  void RunPostProcessors();
+
   // for use by ThreadLocalStorage
 
   /**
@@ -343,6 +348,7 @@ private:
   OwnerPointer<NotificationManager>             mNotificationManager;   ///< Notification manager
   OwnerPointer<GestureEventProcessor>           mGestureEventProcessor; ///< The gesture event processor
   Dali::Vector<Integration::Processor*>         mProcessors;            ///< Registered processors (not owned)
+  Dali::Vector<Integration::Processor*>         mPostProcessors;        ///< Registered post processors those will called after relayout(not owned)
 
   using SceneContainer = std::vector<ScenePtr>;
   SceneContainer mScenes; ///< A container of scenes that bound to a surface for rendering, owned by Core
index 408c2738d5498ab4e470ad9976015730a6872efc..db54144d5ff676c89199a599a33581698df42fc6 100644 (file)
@@ -1118,6 +1118,16 @@ DevelBlendEquation::Type Actor::GetBlendEquation() const
   return mBlendEquation;
 }
 
+void Actor::SetTransparent(bool transparent)
+{
+  SetTransparentMessage(GetEventThreadServices(), GetNode(), transparent);
+}
+
+bool Actor::GetTransparent() const
+{
+  return GetNode().GetTransparent();
+}
+
 void Actor::SetDrawMode(DrawMode::Type drawMode)
 {
   // this flag is not animatable so keep the value
@@ -1397,6 +1407,48 @@ void Actor::Remove(Actor& child)
   mParentImpl.Remove(child);
 }
 
+void Actor::SwitchParent(Actor& newParent)
+{
+  DALI_ASSERT_ALWAYS(this != &newParent && "Cannot add actor to itself");
+
+  DALI_ASSERT_ALWAYS((this->OnScene() && newParent.OnScene()) && "Both of current parent and new parent must be on Scene");
+
+  Actor* oldParent = this->GetParent();
+  if(oldParent->RemoveWithoutNotify(*this))
+  {
+    // Only put in a relayout request if there is a suitable dependency
+    if(oldParent->RelayoutDependentOnChildren())
+    {
+      oldParent->RelayoutRequest();
+    }
+  }
+
+  newParent.AddWithoutNotify(*this);
+  mParent            = &newParent;
+  Actor* parentActor = static_cast<Actor*>(&newParent);
+  mScene             = parentActor->mScene;
+
+  // Resolve the name and index for the child properties if any
+  ResolveChildProperties();
+
+  this->InheritLayoutDirectionRecursively(newParent.GetLayoutDirection());
+  // Only put in a relayout request if there is a suitable dependency
+  if(newParent.RelayoutDependentOnChildren())
+  {
+    newParent.RelayoutRequest();
+  }
+}
+
+void Actor::AddWithoutNotify(Actor& child)
+{
+  mParentImpl.AddWithoutNotify(child);
+}
+
+bool Actor::RemoveWithoutNotify(Actor& child)
+{
+  return mParentImpl.RemoveWithoutNotify(child);
+}
+
 uint32_t Actor::GetChildCount() const
 {
   return mParentImpl.GetChildCount();
@@ -1594,6 +1646,8 @@ void Actor::NotifyStageDisconnection()
     {
       mOnSceneSignalled = false; // signal required next time Actor is added
     }
+
+    SetTransparent(false);
   }
 }
 
index 106af0db48311563f2abed25373a2ed0aff96ef7..959f5f990c0bd9f009b24ad9a50b2840b57fdbe0 100644 (file)
@@ -199,6 +199,21 @@ public:
    */
   void Remove(Actor& child) override;
 
+  /**
+   * @copydoc Dali::DevelActor::SwitchParent()
+   */
+  void SwitchParent(Actor& newParent);
+
+  /**
+   * @copydoc Dali::Internal::ActorParent::AddWithoutNotify()
+   */
+  void AddWithoutNotify(Actor& child);
+
+  /**
+   * @copydoc Dali::Internal::ActorParent::RemoveWithoutNotify()
+   */
+  bool RemoveWithoutNotify(Actor& child);
+
   /**
    * @copydoc Dali::Actor::Unparent
    */
@@ -1214,7 +1229,7 @@ public:
   void RemoveRenderer(uint32_t index);
 
   /**
-   * Set BlendEquation at each renderer that added on this Actor.
+   * @brief Set BlendEquation at each renderer that added on this Actor.
    */
   void SetBlendEquation(DevelBlendEquation::Type blendEquation);
 
@@ -1223,6 +1238,16 @@ public:
    */
   DevelBlendEquation::Type GetBlendEquation() const;
 
+  /**
+   * @brief Set this Actor is transparent or not without any affection on the child Actors.
+   */
+  virtual void SetTransparent(bool transparent);
+
+  /**
+   * @brief Get this Actor is transparent or not.
+   */
+  virtual bool GetTransparent() const;
+
 public:
   /**
    * Converts screen coordinates into the actor's coordinate system.
index c0101ccdafa5523e47e7adef3b96a08c45b02b4e..87b02cdad2163c340b18ba9a4baff6a75a78941f 100644 (file)
@@ -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.
@@ -62,11 +62,6 @@ void ActorParentImpl::Add(Actor& child)
   DALI_ASSERT_ALWAYS(&mOwner != &child && "Cannot add actor to itself");
   DALI_ASSERT_ALWAYS(!child.IsRoot() && "Cannot add root actor");
 
-  if(!mChildren)
-  {
-    mChildren = new ActorContainer;
-  }
-
   Actor* oldParent = child.GetParent();
 
   // child might already be ours
@@ -88,7 +83,7 @@ void ActorParentImpl::Add(Actor& child)
     if(!child.GetParent())
     {
       // Do this first, since user callbacks from within SetParent() may need to remove child
-      mChildren->push_back(ActorPtr(&child));
+      AddWithoutNotify(child);
 
       // SetParent asserts that child can be added
       child.SetParent(&mOwner);
@@ -109,11 +104,45 @@ void ActorParentImpl::Add(Actor& child)
 }
 
 void ActorParentImpl::Remove(Actor& child)
+{
+  bool removed = RemoveWithoutNotify(child);
+
+  if(removed)
+  {
+    child.SetParent(nullptr);
+    // Only put in a relayout request if there is a suitable dependency
+    if(mOwner.RelayoutDependentOnChildren())
+    {
+      mOwner.RelayoutRequest();
+    }
+  }
+
+  // Notification for derived classes
+  mOwner.OnChildRemove(child);
+  EmitChildRemovedSignal(child);
+}
+
+void ActorParentImpl::AddWithoutNotify(Actor& child)
+{
+  if(!mChildren)
+  {
+    mChildren = new ActorContainer;
+  }
+
+  // child might already be ours
+  if(&mOwner != child.GetParent())
+  {
+    // Do this first, since user callbacks from within SetParent() may need to remove child
+    mChildren->push_back(ActorPtr(&child));
+  }
+}
+
+bool ActorParentImpl::RemoveWithoutNotify(Actor& child)
 {
   if((&mOwner == &child) || (!mChildren))
   {
     // no children or removing itself
-    return;
+    return false;
   }
 
   ActorPtr removed;
@@ -133,24 +162,11 @@ void ActorParentImpl::Remove(Actor& child)
       mChildren->erase(iter);
 
       DALI_ASSERT_DEBUG(actor->GetParent() == &mOwner);
-      actor->SetParent(nullptr);
 
       break;
     }
   }
-
-  if(removed)
-  {
-    // Only put in a relayout request if there is a suitable dependency
-    if(mOwner.RelayoutDependentOnChildren())
-    {
-      mOwner.RelayoutRequest();
-    }
-  }
-
-  // Notification for derived classes
-  mOwner.OnChildRemove(child);
-  EmitChildRemovedSignal(child);
+  return removed;
 }
 
 uint32_t ActorParentImpl::GetChildCount() const
index 0f05f8041d370f787eb84dd51e055fb3fc3fd737..16cea6c551c32e0690128f509435e7e6f4ecd7bd 100644 (file)
@@ -61,6 +61,25 @@ public:
    */
   void Remove(Actor& child);
 
+  /**
+   * Adds a child Actor to this ActorParent.
+   * @pre The child actor is not the same as the parent actor.
+   * @pre The child actor could already have a parent.
+   * @param [in] child The child.
+   * @post The child will be referenced by its parent
+   * @note Even though child has already a parent, this method didn't emit off scene callback.
+   */
+  void AddWithoutNotify(Actor& child);
+
+  /**
+   * Removes a child Actor from this ActorParent.
+   * @param [in] child The child.
+   * @post The child will be unreferenced.
+   * @note This method do not call off scene callback of child.
+   * This method must be called just for switching parent Actor.
+   */
+  bool RemoveWithoutNotify(Actor& child);
+
   /**
    * Retrieve the number of children held by the actor.
    * @return The number of children
index 02fc9ce214885715f292639fa90ae27a95cee457..a8362e99a615a73afc570fad21e204b52a7adee7 100644 (file)
@@ -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.
index a70d8845468c4e5db4f8b4b06899bf5ddfae3c79..ab91dfaa7a3473c86d25d088999093517467be43 100644 (file)
@@ -62,6 +62,22 @@ public:
    */
   Dali::TypeInfo GetTypeInfo();
 
+  /**
+   * @copydoc Internal::CustomActorImpl::SetTransparent()
+   */
+  void SetTransparent(bool transparent) override
+  {
+    Actor::SetTransparent(transparent);
+  }
+
+  /**
+   * @copydoc Internal::CustomActorImpl::GetTransparent()
+   */
+  bool GetTransparent() const override
+  {
+    return Actor::GetTransparent();
+  }
+
 protected:
   /**
    * A reference counted object may only be deleted by calling Unreference()
index 662f3e7cd918138532319047c70ea92bc9bb8c5c..ab3e9a296336a39b577a8e051a3398e314b2a0fe 100644 (file)
@@ -101,7 +101,8 @@ Node::Node()
   mClippingMode(ClippingMode::DISABLED),
   mIsRoot(false),
   mIsLayer(false),
-  mPositionUsesAnchorPoint(true)
+  mPositionUsesAnchorPoint(true),
+  mTransparent(false)
 {
   mUniformMapChanged[0] = 0u;
   mUniformMapChanged[1] = 0u;
index 6f6e68164e4c160780049aa7400f1b7ff0d1a04d..07ce46261d368446c4ee728f9b8f495b7dfe63ef 100644 (file)
@@ -725,6 +725,16 @@ public:
     return mDrawMode;
   }
 
+  void SetTransparent(bool transparent)
+  {
+    mTransparent = transparent;
+  }
+
+  bool GetTransparent() const
+  {
+    return mTransparent;
+  }
+
   /*
    * Returns the transform id of the node
    * @return The transform component id of the node
@@ -954,6 +964,7 @@ protected:
   bool               mIsRoot : 1;                  ///< True if the node cannot have a parent
   bool               mIsLayer : 1;                 ///< True if the node is a layer
   bool               mPositionUsesAnchorPoint : 1; ///< True if the node should use the anchor-point when calculating the position
+  bool               mTransparent : 1;
 
   // Changes scope, should be at end of class
   DALI_LOG_OBJECT_STRING_DECLARATION;
@@ -1038,6 +1049,17 @@ inline void SetDrawModeMessage(EventThreadServices& eventThreadServices, const N
   new(slot) LocalType(&node, &Node::SetDrawMode, drawMode);
 }
 
+inline void SetTransparentMessage(EventThreadServices& eventThreadServices, const Node& node, bool transparent)
+{
+  using LocalType = MessageValue1<Node, bool>;
+
+  // Reserve some memory inside the message queue
+  uint32_t* slot = eventThreadServices.ReserveMessageSlot(sizeof(LocalType));
+
+  // Construct message in the message queue memory; note that delete should not be called on the return value
+  new(slot) LocalType(&node, &Node::SetTransparent, transparent);
+}
+
 inline void DetachRendererMessage(EventThreadServices& eventThreadServices, const Node& node, const Renderer& renderer)
 {
   using LocalType = MessageValue1<Node, const Renderer*>;
index 1ecf4ff06c85d4670a8ce20c0f4cc2ca0c00ee4a..f073879b38111e3748eadd3b8df443ca4c154bbb 100644 (file)
@@ -191,7 +191,6 @@ bool Renderer::PrepareRender(BufferIndex updateBufferIndex)
       const UniformMap& rendererUniformMap = PropertyOwner::GetUniformMap();
 
       auto size = rendererUniformMap.Count();
-
       if(mShader)
       {
         size += mShader->GetUniformMap().Count();
@@ -696,6 +695,11 @@ Renderer::OpacityType Renderer::GetOpacityType(BufferIndex updateBufferIndex, co
 {
   Renderer::OpacityType opacityType = Renderer::OPAQUE;
 
+  if(node.GetTransparent())
+  {
+    return Renderer::TRANSPARENT;
+  }
+
   switch(mBlendMode)
   {
     case BlendMode::ON: // If the renderer should always be use blending
index 1ff533bd94329707021a185286d4e2c06f9d2be3..d42e57e78eb1a09b5c93f44fa48ee8160ef3518b 100644 (file)
@@ -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.
@@ -83,4 +83,14 @@ bool CustomActorImpl::RelayoutDependentOnChildrenBase(Dimension::Type dimension)
   return mOwner->RelayoutDependentOnChildrenBase(dimension);
 }
 
+void CustomActorImpl::SetTransparent(bool transparent)
+{
+  mOwner->SetTransparent(transparent);
+}
+
+bool CustomActorImpl::GetTransparent() const
+{
+  return mOwner->GetTransparent();
+}
+
 } // namespace Dali
index 1400f45f51d1defba0dc95e293e19e71960b082a..9c512bd54c4fd789cc9156b4e9382b8c31bfaf5b 100644 (file)
@@ -353,6 +353,16 @@ protected: // For derived classes
    */
   bool RelayoutDependentOnChildrenBase(Dimension::Type dimension = Dimension::ALL_DIMENSIONS);
 
+  /**
+   * @brief Set this CustomActor is transparent or not without any affection on the child Actors.
+   */
+  virtual void SetTransparent(bool transparent);
+
+  /**
+   * @brief Get this CustomActor is transparent or not.
+   */
+  virtual bool GetTransparent() const;
+
 public: // Not intended for application developers
   /**
    * @brief Initializes a CustomActor.
index 43b14781a264baac21eee29ce4c09ef4d57e0e03..32844dad713ae28d5aa28bafa192055b118e587b 100644 (file)
@@ -116,7 +116,6 @@ SET( public_api_core_animation_header_files
   ${public_api_src_dir}/animation/time-period.h
 )
 
-
 SET( public_api_core_common_header_files
   ${public_api_src_dir}/common/constants.h
   ${public_api_src_dir}/common/dali-common.h