#include <dali-toolkit/dali-toolkit.h>
#include <dali-toolkit/dali-toolkit.h>
-#include <dali-toolkit/devel-api/controls/canvas-view/canvas-view.h>
-#include <dali-toolkit/internal/controls/canvas-view/canvas-view-rasterize-thread.h>
+#include <dali-toolkit/internal/controls/canvas-view/canvas-view-impl.h>
+#include <dali-toolkit/internal/controls/canvas-view/canvas-view-rasterize-task.h>
#include <dali/devel-api/adaptor-framework/canvas-renderer/canvas-renderer-shape.h>
#include <dali/devel-api/adaptor-framework/canvas-renderer/canvas-renderer.h>
#include <dali/public-api/images/pixel-data.h>
+#include <dali/public-api/adaptor-framework/async-task-manager.h>
using namespace Dali;
using namespace Toolkit;
END_TEST;
}
-int UtcDaliCanvasViewRasterizeTaskP(void)
-{
- ToolkitTestApplication application;
-
- Dali::Toolkit::Internal::CanvasView* dummyInternalCanvasView = new Dali::Toolkit::Internal::CanvasView(Vector2(100, 100));
- DALI_TEST_CHECK(dummyInternalCanvasView);
-
- Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
- DALI_TEST_CHECK(dummyCanvasRenderer);
-
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
- DALI_TEST_CHECK(task);
-
- END_TEST;
-}
-
-int UtcDaliCanvasViewRasterizeTaskGetCanvasViewP(void)
+bool gRasterizationCompletedSignal = false;
+void rasteriztionCompleted(IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task)
{
- ToolkitTestApplication application;
-
- Dali::Toolkit::Internal::CanvasView* dummyInternalCanvasView = new Dali::Toolkit::Internal::CanvasView(Vector2(100, 100));
- DALI_TEST_CHECK(dummyInternalCanvasView);
-
- Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
- DALI_TEST_CHECK(dummyCanvasRenderer);
-
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
- DALI_TEST_CHECK(task);
-
- DALI_TEST_EQUALS(task->GetCanvasView(), dummyInternalCanvasView, TEST_LOCATION);
-
- END_TEST;
+ gRasterizationCompletedSignal = true;
}
-int UtcDaliCanvasViewRasterizeThreadP(void)
+int UtcDaliCanvasViewRasterizeTaskP(void)
{
ToolkitTestApplication application;
Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
DALI_TEST_CHECK(dummyCanvasRenderer);
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
+ IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyCanvasRenderer, MakeCallback(rasteriztionCompleted));
DALI_TEST_CHECK(task);
- Dali::Toolkit::Internal::CanvasViewRasterizeThread* dummyThread = new Dali::Toolkit::Internal::CanvasViewRasterizeThread();
- DALI_TEST_CHECK(dummyThread);
-
END_TEST;
}
-int UtcDaliCanvasViewRasterizeThreadAddTaskP(void)
+int UtcDaliCanvasViewRasterizeTaskAddTaskP(void)
{
ToolkitTestApplication application;
Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
DALI_TEST_CHECK(dummyCanvasRenderer);
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
+ IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyCanvasRenderer, MakeCallback(rasteriztionCompleted));
DALI_TEST_CHECK(task);
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task2 = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
+ IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task2 = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyCanvasRenderer, MakeCallback(rasteriztionCompleted));
DALI_TEST_CHECK(task2);
- Dali::Toolkit::Internal::CanvasViewRasterizeThread* dummyThread = new Dali::Toolkit::Internal::CanvasViewRasterizeThread();
- DALI_TEST_CHECK(dummyThread);
-
- dummyThread->AddTask(task);
- dummyThread->AddTask(task2);
-
- END_TEST;
-}
-
-int UtcDaliCanvasViewRasterizeThreadAddRemoveTaskP(void)
-{
- ToolkitTestApplication application;
-
- Dali::Toolkit::Internal::CanvasView* dummyInternalCanvasView = new Dali::Toolkit::Internal::CanvasView(Vector2(100, 100));
- DALI_TEST_CHECK(dummyInternalCanvasView);
-
- Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
- DALI_TEST_CHECK(dummyCanvasRenderer);
-
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
- DALI_TEST_CHECK(task);
-
- Dali::Toolkit::Internal::CanvasViewRasterizeThread* dummyThread = new Dali::Toolkit::Internal::CanvasViewRasterizeThread();
- DALI_TEST_CHECK(dummyThread);
-
- dummyThread->AddTask(task);
+ Dali::AsyncTaskManager asyncTaskManager = Dali::AsyncTaskManager::Get();
+ DALI_TEST_CHECK(asyncTaskManager);
- dummyThread->RemoveTask(dummyInternalCanvasView);
+ asyncTaskManager.AddTask(task);
+ asyncTaskManager.AddTask(task2);
END_TEST;
}
-int UtcDaliCanvasViewRasterizeThreadApplyRasterizedP(void)
+int UtcDaliCanvasViewRasterizeTaskAddRemoveTaskP(void)
{
ToolkitTestApplication application;
Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
DALI_TEST_CHECK(dummyCanvasRenderer);
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
+ IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyCanvasRenderer, MakeCallback(rasteriztionCompleted));
DALI_TEST_CHECK(task);
- Dali::Toolkit::Internal::CanvasViewRasterizeThread* dummyThread = new Dali::Toolkit::Internal::CanvasViewRasterizeThread();
- DALI_TEST_CHECK(dummyThread);
+ Dali::AsyncTaskManager asyncTaskManager = Dali::AsyncTaskManager::Get();
+ DALI_TEST_CHECK(asyncTaskManager);
- dummyThread->AddTask(task);
+ asyncTaskManager.AddTask(task);
- dummyThread->ApplyRasterized();
-
- END_TEST;
-}
-
-int UtcDaliCanvasViewRasterizeThreadTerminateThreadP(void)
-{
- ToolkitTestApplication application;
-
- Dali::Toolkit::Internal::CanvasView* dummyInternalCanvasView = new Dali::Toolkit::Internal::CanvasView(Vector2(100, 100));
- DALI_TEST_CHECK(dummyInternalCanvasView);
-
- Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
- DALI_TEST_CHECK(dummyCanvasRenderer);
-
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
- DALI_TEST_CHECK(task);
-
- Dali::Toolkit::Internal::CanvasViewRasterizeThread* dummyThread = new Dali::Toolkit::Internal::CanvasViewRasterizeThread();
- DALI_TEST_CHECK(dummyThread);
-
- dummyThread->AddTask(task);
-
- Dali::Toolkit::Internal::CanvasViewRasterizeThread::TerminateThread(dummyThread);
+ asyncTaskManager.RemoveTask(task);
END_TEST;
}
return pixelData;
}
-int UtcDaliCanvasViewRasterizeThreadCallProcessP(void)
+int UtcDaliCanvasViewRasterizeThreadRasterizationCompletedSignalP(void)
{
ToolkitTestApplication application;
- Dali::Toolkit::Internal::CanvasView* dummyInternalCanvasView = new Dali::Toolkit::Internal::CanvasView(Vector2(100, 100));
- DALI_TEST_CHECK(dummyInternalCanvasView);
+ gRasterizationCompletedSignal = false;
+
+ Dali::Toolkit::CanvasView canvasView = Dali::Toolkit::CanvasView::New(Vector2(100, 100));
Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
DALI_TEST_CHECK(dummyCanvasRenderer);
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyInternalCanvasView, dummyCanvasRenderer);
+ IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(dummyCanvasRenderer, MakeCallback(rasteriztionCompleted));
DALI_TEST_CHECK(task);
- Dali::Toolkit::Internal::CanvasViewRasterizeThread* dummyThread = new Dali::Toolkit::Internal::CanvasViewRasterizeThread();
- DALI_TEST_CHECK(dummyThread);
+ Dali::AsyncTaskManager asyncTaskManager = Dali::AsyncTaskManager::Get();
+ DALI_TEST_CHECK(asyncTaskManager);
+
+ asyncTaskManager.AddTask(task);
- dummyThread->AddTask(task);
+ DALI_TEST_EQUALS(Test::WaitForEventThreadTrigger(1), true, TEST_LOCATION);
+ application.SendNotification();
+ application.Render();
- dummyThread->Process(false);
+ DALI_TEST_EQUALS(gRasterizationCompletedSignal, true, TEST_LOCATION);
END_TEST;
}
-int UtcDaliCanvasViewRasterizeThreadRasterizationCompletedSignalP(void)
+int UtcDaliCanvasViewSetSizeAndAddDrawable(void)
{
ToolkitTestApplication application;
- Dali::Toolkit::CanvasView canvasView = Dali::Toolkit::CanvasView::New(Vector2(100, 100));
- Dali::Toolkit::Internal::CanvasView& dummyInternalCanvasView = GetImpl(canvasView);
-
- Dali::CanvasRenderer dummyCanvasRenderer = Dali::CanvasRenderer::New(Vector2(100, 100));
- DALI_TEST_CHECK(dummyCanvasRenderer);
+ CanvasView canvasView = CanvasView::New(Vector2(100, 100));
+ DALI_TEST_CHECK(canvasView);
- IntrusivePtr<Dali::Toolkit::Internal::CanvasRendererRasterizingTask> task = new Dali::Toolkit::Internal::CanvasRendererRasterizingTask(&dummyInternalCanvasView, dummyCanvasRenderer);
- DALI_TEST_CHECK(task);
+ application.GetScene().Add(canvasView);
- Dali::Toolkit::Internal::CanvasViewRasterizeThread* dummyThread = new Dali::Toolkit::Internal::CanvasViewRasterizeThread();
- DALI_TEST_CHECK(dummyThread);
+ canvasView.SetProperty(Actor::Property::SIZE, Vector2(300, 300));
- dummyThread->AddTask(task);
+ application.SendNotification();
+ application.Render();
- dummyThread->Process(false);
+ Dali::CanvasRenderer::Shape shape = Dali::CanvasRenderer::Shape::New();
- auto texture = Texture::New(Dali::TextureType::TEXTURE_2D, Pixel::RGBA8888, 100, 100);
+ shape.AddRect(Rect<float>(10, 10, 10, 10), Vector2(0, 0));
- dummyThread->RasterizationCompletedSignal().Connect(&dummyInternalCanvasView, &Dali::Toolkit::Internal::CanvasView::ApplyRasterizedImage);
- dummyThread->RasterizationCompletedSignal().Emit(texture);
+ canvasView.AddDrawable(shape);
application.SendNotification();
application.Render();
END_TEST;
}
-int UtcDaliCanvasViewSetSizeAndAddDrawable(void)
+int UtcDaliCanvasViewSetSizeAndAddDrawableAsync(void)
{
ToolkitTestApplication application;
application.GetScene().Add(canvasView);
+ canvasView.SetProperty(Toolkit::CanvasView::Property::SYNCHRONOUS_LOADING, false);
canvasView.SetProperty(Actor::Property::SIZE, Vector2(300, 300));
application.SendNotification();
END_TEST;
}
+
+int UtcDaliCanvasViewSychronousLoading(void)
+{
+ ToolkitTestApplication application;
+
+ CanvasView canvasView = CanvasView::New(Vector2(300, 300));
+ DALI_TEST_CHECK(canvasView);
+
+ application.GetScene().Add(canvasView);
+
+ canvasView.SetProperty(Actor::Property::SIZE, Vector2(300, 300));
+
+ application.SendNotification();
+ application.Render();
+
+ bool isSynchronous = canvasView.GetProperty(Toolkit::CanvasView::Property::SYNCHRONOUS_LOADING).Get<bool>();
+ DALI_TEST_EQUALS(isSynchronous, true, TEST_LOCATION);
+
+ canvasView.SetProperty(Toolkit::CanvasView::Property::SYNCHRONOUS_LOADING, false);
+
+ application.SendNotification();
+ application.Render();
+
+ isSynchronous = canvasView.GetProperty(Toolkit::CanvasView::Property::SYNCHRONOUS_LOADING).Get<bool>();
+ DALI_TEST_EQUALS(isSynchronous, false, TEST_LOCATION);
+
+ END_TEST;
+}