Revert "[Tizen] Restore Uploaded signal for BufferImage and ResourceImage"
[platform/core/uifw/dali-core.git] / dali / internal / event / images / frame-buffer-image-impl.h
index 62e3c58..7e69797 100644 (file)
@@ -2,7 +2,7 @@
 #define __DALI_INTERNAL_FRAME_BUFFER_IMAGE_H__
 
 /*
- * Copyright (c) 2014 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2015 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.
@@ -21,6 +21,7 @@
 // INTERNAL INCLUDES
 #include <dali/internal/event/images/image-impl.h>
 #include <dali/public-api/images/frame-buffer-image.h>
+#include <dali/internal/event/rendering/frame-buffer-impl.h>
 
 namespace Dali
 {
@@ -37,51 +38,39 @@ typedef IntrusivePtr<FrameBufferImage> FrameBufferImagePtr;
 class FrameBufferImage : public Image
 {
 public:
+
   /**
    * @copydoc Dali::FrameBufferImage::New(unsigned int, unsigned int, Pixel::Format)
    */
-  static FrameBufferImagePtr  New(unsigned int width, unsigned int height, Pixel::Format pixelFormat, ReleasePolicy releasePolicy);
+  static FrameBufferImagePtr New( unsigned int width, unsigned int height, Pixel::Format pixelFormat, RenderBuffer::Format bufferformat );
 
   /**
    * @copydoc Dali::FrameBufferImage::New(NativeImageInterface&)
    */
-  static FrameBufferImagePtr  New( NativeImageInterface& nativeImage );
-
-  /**
-   * @copydoc Dali::FrameBufferImage::New(NativeImageInterface&, ReleasePolicy)
-   */
-  static FrameBufferImagePtr  New( NativeImageInterface& nativeImage, ReleasePolicy releasePolicy );
-
-  /**
-   * @copydoc Dali::FrameBufferImage::FrameBufferImage
-   */
-  FrameBufferImage(unsigned int width, unsigned int height, Pixel::Format pixelFormat);
-
-  /**
-   * @copydoc Dali::FrameBufferImage::FrameBufferImage
-   */
-  FrameBufferImage(unsigned int width, unsigned int height, Pixel::Format pixelFormat, ReleasePolicy releasePolicy);
+  static FrameBufferImagePtr New( NativeImageInterface& nativeImage );
 
   /**
    * @copydoc Dali::FrameBufferImage::FrameBufferImage
    */
-  FrameBufferImage(NativeImageInterface& image);
+  FrameBufferImage( unsigned int width, unsigned int height );
 
   /**
    * @copydoc Dali::FrameBufferImage::FrameBufferImage
    */
-  FrameBufferImage(NativeImageInterface& image, ReleasePolicy releasePolicy);
+  FrameBufferImage( NativeImageInterface& image );
 
-public: // From Image
   /**
-   * @copydoc Dali::Internal::Image::Connect()
+   * @return true if this FBO is targeting a NativeImageInterface
    */
-  virtual void Connect();
+  bool IsNativeFbo() const;
 
   /**
-   * @copydoc Dali::Internal::Image::Disconnect()
+   * @return Internal FrameBuffer used by this FrameBufferImage
    */
-  virtual void Disconnect();
+  FrameBuffer* GetFrameBuffer() const
+  {
+    return mFrameBufferObject.Get();
+  }
 
 protected:
   /**
@@ -91,8 +80,9 @@ protected:
 
 private:
   // cached values for the size / pixel format we were created with. Needed to recreate us when we Connect() to stage and mTicket was reset from a previous call to Disconnect().
+  FrameBufferPtr  mFrameBufferObject;
   NativeImageInterfacePtr mNativeImage;
-  Pixel::Format mPixelFormat;
+  bool mIsNativeFbo;
 }; // class FrameBufferImage
 
 } // namespace Internal