/*
- * Copyright (c) 2015 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2017 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.
// INTERNAL INCLUDES
#include <dali/internal/update/manager/update-manager.h>
#include <dali/internal/event/common/stage-impl.h>
+#include <dali/integration-api/render-controller.h>
namespace Dali
{
namespace Internal
{
-NewTexturePtr NewTexture::New(TextureType::Type type, Pixel::Format format, unsigned int width, unsigned int height )
+TexturePtr Texture::New(TextureType::Type type, Pixel::Format format, unsigned int width, unsigned int height )
{
- NewTexturePtr texture( new NewTexture( type, format, width, height ) );
+ constexpr auto max_value = std::numeric_limits< uint16_t >::max();
+ DALI_ASSERT_ALWAYS( ( width < max_value )&&( height < max_value )&& "Size out of range" );
+ TexturePtr texture( new Texture( type, format, ImageDimensions( width, height) ) );
texture->Initialize();
return texture;
}
+TexturePtr Texture::New( NativeImageInterface& nativeImageInterface )
+{
+ TexturePtr texture( new Texture( &nativeImageInterface ) );
+ texture->Initialize();
+ return texture;
+}
-Render::NewTexture* NewTexture::GetRenderObject() const
+Render::Texture* Texture::GetRenderObject() const
{
return mRenderObject;
}
-NewTexture::NewTexture(TextureType::Type type, Pixel::Format format, unsigned int width, unsigned int height )
+Texture::Texture(TextureType::Type type, Pixel::Format format, ImageDimensions size )
: mEventThreadServices( *Stage::GetCurrent() ),
mRenderObject( NULL ),
+ mNativeImage(),
+ mSize( size ),
mType( type ),
- mFormat( format ),
- mWidth( width ),
- mHeight( height )
+ mFormat( format )
{
}
-void NewTexture::Initialize()
+Texture::Texture( NativeImageInterfacePtr nativeImageInterface )
+: mEventThreadServices( *Stage::GetCurrent() ),
+ mRenderObject( NULL ),
+ mNativeImage( nativeImageInterface ),
+ mSize( nativeImageInterface->GetWidth(), nativeImageInterface->GetHeight() ),
+ mType( TextureType::TEXTURE_2D ),
+ mFormat( Pixel::RGB888 )
{
- mRenderObject = new Render::NewTexture( mType, mFormat, mWidth, mHeight );
- AddTexture( mEventThreadServices.GetUpdateManager(), *mRenderObject );
}
-NewTexture::~NewTexture()
+void Texture::Initialize()
{
- if( EventThreadServices::IsCoreRunning() && mRenderObject )
+ if( EventThreadServices::IsCoreRunning() )
{
- RemoveTexture( mEventThreadServices.GetUpdateManager(), *mRenderObject );
+ if( mNativeImage )
+ {
+ mRenderObject = new Render::Texture( mNativeImage );
+ }
+ else
+ {
+ mRenderObject = new Render::Texture( mType, mFormat, mSize );
+ }
+
+ OwnerPointer< Render::Texture > transferOwnership( mRenderObject );
+ AddTexture( mEventThreadServices.GetUpdateManager(), transferOwnership );
}
}
-bool NewTexture::CheckUploadParametres( const Vector<unsigned char>& buffer, const UploadParams& parameters ) const
+Texture::~Texture()
{
- if( buffer.Size() < GetBytesPerPixel( mFormat ) * parameters.width * parameters.height )
- {
- DALI_LOG_ERROR( "Error: Buffer of an incorrect size when trying to update texture");
- return false;
- }
- else if( ( parameters.xOffset + parameters.width > static_cast<unsigned int>( mWidth/(1<<parameters.mipmap ))) ||
- ( parameters.yOffset + parameters.height > static_cast<unsigned int>( mHeight/(1<<parameters.mipmap ))))
- {
- DALI_LOG_ERROR( "Error: Out of bounds texture update");
- return false;
- }
- else
+ if( EventThreadServices::IsCoreRunning() && mRenderObject )
{
- return true;
+ RemoveTexture( mEventThreadServices.GetUpdateManager(), *mRenderObject );
}
}
-void NewTexture::Upload( Vector<unsigned char>& buffer,
- unsigned int layer, unsigned int mipmap,
- unsigned int xOffset, unsigned int yOffset,
- unsigned int width, unsigned int height )
+bool Texture::Upload( PixelDataPtr pixelData )
{
- UploadParams params = { layer, mipmap, xOffset, yOffset, width, height };
- if( CheckUploadParametres( buffer, params ) )
- {
- UploadTextureMessage(mEventThreadServices.GetUpdateManager(), *mRenderObject, buffer, params );
- }
+ return Upload( pixelData, 0u, 0u, 0u, 0u, pixelData->GetWidth(), pixelData->GetHeight() );
}
-void NewTexture::Upload( Vector<unsigned char>& buffer )
+bool Texture::Upload( PixelDataPtr pixelData,
+ unsigned int layer, unsigned int mipmap,
+ unsigned int xOffset, unsigned int yOffset,
+ unsigned int width, unsigned int height )
{
- UploadParams params = {0u,0u,0u,0u,mWidth,mHeight};
- if( CheckUploadParametres( buffer, params ) )
+ constexpr auto max_value = std::numeric_limits< uint16_t >::max();
+ DALI_ASSERT_ALWAYS( layer < max_value &&
+ mipmap < max_value &&
+ xOffset < max_value &&
+ yOffset < max_value &&
+ width < max_value &&
+ height < max_value &&
+ "Parameter value out of range" );
+
+ bool result(false);
+ if( EventThreadServices::IsCoreRunning() && mRenderObject )
{
- UploadTextureMessage(mEventThreadServices.GetUpdateManager(), *mRenderObject, buffer, params );
+ if( mNativeImage )
+ {
+ DALI_LOG_ERROR( "OpenGL ES does not support uploading data to native texture\n");
+ }
+ else
+ {
+ unsigned int pixelDataSize = pixelData->GetWidth()*pixelData->GetHeight();
+ if( pixelData->GetBuffer() == NULL || pixelDataSize == 0 )
+ {
+ DALI_LOG_ERROR( "PixelData is empty\n");
+ }
+ else
+ {
+ Pixel::Format pixelDataFormat = pixelData->GetPixelFormat();
+ if( ( pixelDataFormat == mFormat ) || ( (pixelDataFormat == Pixel::RGB888 ) && ( mFormat == Pixel::RGBA8888 ) ) )
+ {
+ if( pixelDataSize < width * height )
+ {
+ DALI_LOG_ERROR( "PixelData of an incorrect size when trying to update texture\n");
+ }
+ else if( ( xOffset + width > ( mSize.GetWidth() / (1u << mipmap) ) ) ||
+ ( yOffset + height > ( mSize.GetHeight() / (1u << mipmap) ) ) )
+ {
+ DALI_LOG_ERROR( "Texture update area out of bounds\n");
+ }
+ else
+ {
+ //Parameters are correct. Send message to upload data to the texture
+ UploadParams params = { static_cast< uint16_t >( layer ),
+ static_cast< uint16_t >( mipmap ),
+ static_cast< uint16_t >( xOffset ),
+ static_cast< uint16_t >( yOffset ),
+ static_cast< uint16_t >( width ),
+ static_cast< uint16_t >( height ) };
+ UploadTextureMessage( mEventThreadServices.GetUpdateManager(), *mRenderObject, pixelData, params );
+
+ // Request event processing and update forcely
+ mEventThreadServices.GetRenderController().RequestProcessEventsOnIdle( true );
+ mEventThreadServices.ForceNextUpdate();
+
+ result = true;
+ }
+ }
+ else
+ {
+ DALI_LOG_ERROR( "Bad format\n");
+ }
+ }
+ }
}
+
+ return result;
}
-void NewTexture::GenerateMipmaps()
+void Texture::GenerateMipmaps()
{
- GenerateMipmapsMessage(mEventThreadServices.GetUpdateManager(), *mRenderObject );
+ if( EventThreadServices::IsCoreRunning() && mRenderObject )
+ {
+ GenerateMipmapsMessage(mEventThreadServices.GetUpdateManager(), *mRenderObject );
+ }
}
-unsigned int NewTexture::GetWidth() const
+unsigned int Texture::GetWidth() const
{
- return mWidth;
+ return mSize.GetWidth();
}
-unsigned int NewTexture::GetHeight() const
+unsigned int Texture::GetHeight() const
{
- return mHeight;
+ return mSize.GetHeight();
}
} // namespace Internal