staging_texture.h
1 /*
2 ** UICore
3 ** Copyright (c) 1997-2015 The UICore Team
4 **
5 ** This software is provided 'as-is', without any express or implied
6 ** warranty. In no event will the authors be held liable for any damages
7 ** arising from the use of this software.
8 **
9 ** Permission is granted to anyone to use this software for any purpose,
10 ** including commercial applications, and to alter it and redistribute it
11 ** freely, subject to the following restrictions:
12 **
13 ** 1. The origin of this software must not be misrepresented; you must not
14 ** claim that you wrote the original software. If you use this software
15 ** in a product, an acknowledgment in the product documentation would be
16 ** appreciated but is not required.
17 ** 2. Altered source versions must be plainly marked as such, and must not be
18 ** misrepresented as being the original software.
19 ** 3. This notice may not be removed or altered from any source distribution.
20 **
21 ** Note: Some of the libraries UICore may link to may have additional
22 ** requirements or restrictions.
23 **
24 ** File Author(s):
25 **
26 ** Magnus Norddahl
27 ** Mark Page
28 */
29 
30 #pragma once
31 
32 #include <memory>
33 #include "graphic_context.h"
34 #include "../Image/image_import_description.h"
35 #include "../Image/texture_format.h"
36 #include "../Image/pixel_buffer.h"
37 #include "buffer_usage.h"
38 
39 namespace uicore
40 {
41  class Color;
42  class Point;
43  class PixelBuffer;
44  class PixelFormat;
45 
47  enum class StagingDirection : int
48  {
50  to_gpu,
51 
53  from_gpu
54  };
55 
57  class StagingTexture : public PixelBuffer
58  {
59  public:
70  static std::shared_ptr<StagingTexture> create(const GraphicContextPtr &gc, int width, int height, StagingDirection direction = StagingDirection::to_gpu, TextureFormat texture_format = tf_rgba8, const void *data = nullptr, BufferUsage usage = usage_stream_draw);
71  static std::shared_ptr<StagingTexture> create(const GraphicContextPtr &gc, const PixelBufferPtr &pbuff, StagingDirection direction = StagingDirection::to_gpu, BufferUsage usage = usage_stream_draw);
72 
76  virtual void lock(const GraphicContextPtr &gc, BufferAccess access) = 0;
77 
79  virtual void unlock() = 0;
80 
82  virtual void upload_data(const GraphicContextPtr &gc, const Rect &dest_rect, const void *data) = 0;
83  };
84 
85  typedef std::shared_ptr<StagingTexture> StagingTexturePtr;
86 }
Definition: buffer_usage.h:37
virtual int width() const =0
Retrieves the width of the buffer.
BufferUsage
Array Buffer usage enum.
Definition: buffer_usage.h:35
virtual void lock(const GraphicContextPtr &gc, BufferAccess access)=0
Maps buffer into system memory.
Pixel data container.
Definition: pixel_buffer.h:52
std::shared_ptr< StagingTexture > StagingTexturePtr
Definition: staging_texture.h:85
Texture Transfer class.
Definition: staging_texture.h:57
TextureFormat
Texture format.
Definition: texture_format.h:35
Definition: texture_format.h:38
virtual void unlock()=0
Unmaps buffer.
virtual void * data()=0
Returns a pointer to the beginning of the pixel buffer.
Use of the pixel buffer is to send data to the gpu.
2D (left,top,right,bottom) rectangle structure - Integer
Definition: rect.h:491
Use of the pixel buffer is to retrieve data from the gpu.
BufferAccess
Array Buffer access enum.
Definition: buffer_usage.h:49
StagingDirection
Staging usage direction.
Definition: staging_texture.h:47
virtual int height() const =0
Retrieves the height of the buffer.
std::shared_ptr< PixelBuffer > PixelBufferPtr
Definition: d3d_target.h:39
std::shared_ptr< GraphicContext > GraphicContextPtr
Definition: d3d_target.h:49
virtual void upload_data(const GraphicContextPtr &gc, const Rect &dest_rect, const void *data)=0
Uploads data to buffer.
Definition: Application/application.h:35
static std::shared_ptr< StagingTexture > create(const GraphicContextPtr &gc, int width, int height, StagingDirection direction=StagingDirection::to_gpu, TextureFormat texture_format=tf_rgba8, const void *data=nullptr, BufferUsage usage=usage_stream_draw)
Constructs a GPU Transfer Buffer.