+ tet_infoline( "Original control correctly signalled, now testing for signal with new Control reusing the image" );
+
+ gResourceReadySignalFired = false; // Reset signal check ready for testing next Control
+ Visual::Base imageVisual2 = CreateVisualWithPolicy( TEST_IMAGE_FILE_NAME, DevelImageVisual::Property::LOAD_POLICY, DevelImageVisual::LoadPolicy::ATTACHED );
+ DummyControl actor2 = DummyControl::New(true);
+ Impl::DummyControl& dummyImpl2 = static_cast<Impl::DummyControl&>(actor.GetImplementation());
+ actor2.ResourceReadySignal().Connect( &ResourceReadySignal);
+
+ tet_infoline( "Registering visual this should trigger the loading signal as is already image loaded for previous control" );
+ dummyImpl2.RegisterVisual( DummyControl::Property::TEST_VISUAL, imageVisual2 );
+ imageVisual2.Reset(); // reduce ref count so only the control keeps the visual alive.
+ actor2.SetSize(200.f, 200.f);
+ DALI_TEST_EQUALS( Test::WaitForEventThreadTrigger( 0 ), true, TEST_LOCATION ); // Not expecting any further loading as texture is being reused.
+ DALI_TEST_EQUALS( gResourceReadySignalFired, true, TEST_LOCATION );
+
+ END_TEST;
+}
+
+
+int UtcDaliImageVisualOrientationCorrection(void)
+{
+ ToolkitTestApplication application;
+ tet_infoline( "UtcDaliImageVisualOrientationCorrection Enabling OrientationCorrection should rotate an image with exif (90deg) orientation data with requested" );
+
+ VisualFactory factory = VisualFactory::Get();
+ tet_infoline( "Create visual with Orientation correction set OFF" );
+ Property::Map propertyMap;
+ propertyMap.Insert( Visual::Property::TYPE, Visual::IMAGE );
+ propertyMap.Insert( ImageVisual::Property::URL, TEST_ROTATED_IMAGE );
+ propertyMap.Insert( DevelImageVisual::Property::ORIENTATION_CORRECTION, false );
+ Visual::Base imageVisual = factory.CreateVisual( propertyMap );
+
+ tet_infoline( "Create control for visual, need to loaded it" );
+ DummyControl actor = DummyControl::New(true);
+ Impl::DummyControl& dummyImpl = static_cast<Impl::DummyControl&>(actor.GetImplementation());
+ Stage::GetCurrent().Add( actor );
+
+ dummyImpl.RegisterVisual( DummyControl::Property::TEST_VISUAL, imageVisual );
+ // Wait for image to load
+ DALI_TEST_EQUALS( Test::WaitForEventThreadTrigger( 1 ), true, TEST_LOCATION );
+
+ Vector2 originalImageSize;
+ tet_infoline( "Get size of original visual to compare later with rotated image" );
+ imageVisual.GetNaturalSize( originalImageSize );
+ DALI_TEST_GREATER( originalImageSize.width, originalImageSize.height, TEST_LOCATION ); // Width and Height must be different for this test.
+ imageVisual.Reset(); // remove handle so can unregister it and remove from cache
+ dummyImpl.UnregisterVisual( DummyControl::Property::TEST_VISUAL );
+ application.SendNotification();
+ application.Render();
+
+ tet_infoline( "Create visual with Orientation correction set ON " );
+ propertyMap.Clear();
+ propertyMap.Insert( Visual::Property::TYPE, Visual::IMAGE );
+ propertyMap.Insert( ImageVisual::Property::URL, TEST_ROTATED_IMAGE );
+ propertyMap.Insert( DevelImageVisual::Property::ORIENTATION_CORRECTION, true );
+ imageVisual = factory.CreateVisual( propertyMap );
+
+ dummyImpl.RegisterVisual( DummyControl::Property::TEST_VISUAL, imageVisual );
+ // Wait for image to load
+ DALI_TEST_EQUALS( Test::WaitForEventThreadTrigger( 1 ), true, TEST_LOCATION );
+
+ Vector2 rotatedImageSize;
+ imageVisual.GetNaturalSize( rotatedImageSize );
+ tet_infoline( "Confirm that visual has rotated" );
+ DALI_TEST_EQUALS( originalImageSize.width, rotatedImageSize.height , TEST_LOCATION );
+ DALI_TEST_EQUALS( originalImageSize.height, rotatedImageSize.width , TEST_LOCATION );
+
+ Property::Map resultMap;
+ imageVisual.CreatePropertyMap( resultMap );
+
+ // check the Property::ORIENTATION_CORRECTION value from the returned map
+ Property::Value* typeValue = resultMap.Find( DevelImageVisual::Property::ORIENTATION_CORRECTION, Property::BOOLEAN );
+ DALI_TEST_EQUALS( typeValue->Get<bool>(), true, TEST_LOCATION );
+