#pragma once #include #include #include #include #include #include namespace mbgl { namespace gfx { class Context { protected: Context() = default; public: Context(Context&&) = delete; Context(const Context&) = delete; Context& operator=(Context&& other) = delete; Context& operator=(const Context& other) = delete; virtual ~Context() = default; public: template VertexBuffer createVertexBuffer(VertexVector&& v, const BufferUsageType usage = BufferUsageType::StaticDraw) { return { v.elements(), createVertexBufferResource(v.data(), v.bytes(), usage) }; } template void updateVertexBuffer(VertexBuffer& buffer, VertexVector&& v) { assert(v.elements() == buffer.elements); updateVertexBufferResource(*buffer.resource, v.data(), v.bytes()); } template IndexBuffer createIndexBuffer(IndexVector&& v, const BufferUsageType usage = BufferUsageType::StaticDraw) { return { v.elements(), createIndexBufferResource(v.data(), v.bytes(), usage) }; } template void updateIndexBuffer(IndexBuffer& buffer, IndexVector&& v) { assert(v.elements() == buffer.elements); updateIndexBufferResource(*buffer.resource, v.data(), v.bytes()); } protected: virtual std::unique_ptr createVertexBufferResource(const void* data, std::size_t size, const BufferUsageType) = 0; virtual void updateVertexBufferResource(const VertexBufferResource&, const void* data, std::size_t size) = 0; virtual std::unique_ptr createIndexBufferResource(const void* data, std::size_t size, const BufferUsageType) = 0; virtual void updateIndexBufferResource(const IndexBufferResource&, const void* data, std::size_t size) = 0; public: // Create a texture from an image with data. template Texture createTexture(const Image& image, uint8_t unit = 0, TextureChannelDataType type = TextureChannelDataType::UnsignedByte) { auto format = image.channels == 4 ? TexturePixelType::RGBA : TexturePixelType::Alpha; return { image.size, createTextureResource(image.size, image.data.get(), format, unit, type) }; } // Creates an empty texture with the specified dimensions. Texture createTexture(const Size size, TexturePixelType format = TexturePixelType::RGBA, uint8_t unit = 0, TextureChannelDataType type = TextureChannelDataType::UnsignedByte) { return { size, createTextureResource(size, nullptr, format, unit, type) }; } template void updateTexture(Texture& texture, const Image& image, uint8_t unit = 0, TextureChannelDataType type = TextureChannelDataType::UnsignedByte) { auto format = image.channels == 4 ? TexturePixelType::RGBA : TexturePixelType::Alpha; updateTextureResource(*texture.resource, image.size, image.data.get(), format, unit, type); texture.size = image.size; } virtual void bindTexture(Texture&, uint8_t unit = 0, TextureFilterType = TextureFilterType::Nearest, TextureMipMapType = TextureMipMapType::No, TextureWrapType wrapX = TextureWrapType::Clamp, TextureWrapType wrapY = TextureWrapType::Clamp) = 0; protected: virtual std::unique_ptr createTextureResource( Size, const void* data, TexturePixelType, uint8_t unit, TextureChannelDataType) = 0; virtual void updateTextureResource(const TextureResource&, Size, const void* data, TexturePixelType, uint8_t unit, TextureChannelDataType) = 0; }; } // namespace gfx } // namespace mbgl