2019-11-23 20:27:39 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2018-2019 Xiamen Yaji Software Co., Ltd.
|
|
|
|
|
2022-10-01 16:24:52 +08:00
|
|
|
https://axmolengine.github.io/
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <cstdint>
|
|
|
|
|
2023-06-11 13:08:08 +08:00
|
|
|
#include "base/Ref.h"
|
|
|
|
#include "base/Data.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
#include "Macros.h"
|
|
|
|
#include "Types.h"
|
2021-04-22 22:01:47 +08:00
|
|
|
#include "RenderPassDescriptor.h"
|
2020-09-10 21:14:28 +08:00
|
|
|
#include "PixelBufferDescriptor.h"
|
2023-07-29 21:30:35 +08:00
|
|
|
#include "platform/StdC.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
#include "ProgramState.h"
|
|
|
|
#include "VertexLayout.h"
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <vector>
|
|
|
|
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_BEGIN
|
2020-09-22 16:32:17 +08:00
|
|
|
struct PipelineDescriptor;
|
2023-06-12 14:15:37 +08:00
|
|
|
NS_AX_END
|
2020-09-22 16:32:17 +08:00
|
|
|
|
2023-06-12 14:15:37 +08:00
|
|
|
NS_AX_BACKEND_BEGIN
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
class RenderPass;
|
|
|
|
class RenderPipeline;
|
|
|
|
class Buffer;
|
|
|
|
class DepthStencilState;
|
2020-09-11 00:10:44 +08:00
|
|
|
class TextureBackend;
|
2020-09-21 22:10:50 +08:00
|
|
|
class RenderTarget;
|
2020-09-22 16:32:17 +08:00
|
|
|
struct DepthStencilDescriptor;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @addtogroup _backend
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Store encoded commands for the GPU to execute.
|
|
|
|
* A command buffer stores encoded commands until the buffer is committed for execution by the GPU
|
|
|
|
*/
|
2022-08-08 18:02:17 +08:00
|
|
|
class CommandBuffer : public ax::Ref
|
2019-11-23 20:27:39 +08:00
|
|
|
{
|
|
|
|
public:
|
2020-09-22 16:32:17 +08:00
|
|
|
/**
|
|
|
|
* Set depthStencil status once
|
|
|
|
* @param depthStencilState Specifies the depth and stencil status
|
|
|
|
*/
|
|
|
|
virtual void setDepthStencilState(DepthStencilState* depthStencilState) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the current render pipeline state object once
|
2021-12-25 10:04:45 +08:00
|
|
|
* @param renderPipeline An object that contains the graphics functions and configuration state used in a render
|
|
|
|
* pass.
|
2020-09-22 16:32:17 +08:00
|
|
|
*/
|
|
|
|
virtual void setRenderPipeline(RenderPipeline* renderPipeline) = 0;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/// @name Setters & Getters
|
|
|
|
/**
|
|
|
|
* @brief Indicate the begining of a frame
|
|
|
|
*/
|
2021-04-22 22:01:47 +08:00
|
|
|
virtual bool beginFrame() = 0;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Begin a render pass, initial color, depth and stencil attachment.
|
|
|
|
* @param descriptor Specifies a group of render targets that hold the results of a render pass.
|
|
|
|
*/
|
2021-04-22 22:01:47 +08:00
|
|
|
virtual void beginRenderPass(const RenderTarget* renderTarget, const RenderPassDescriptor& descriptor) = 0;
|
2020-09-22 16:32:17 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
2020-09-22 16:32:17 +08:00
|
|
|
* Update depthStencil status, improvment: for metal backend cache it
|
|
|
|
* @param depthStencilState Specifies the depth and stencil status
|
2019-11-23 20:27:39 +08:00
|
|
|
*/
|
2020-09-22 16:32:17 +08:00
|
|
|
virtual void updateDepthStencilState(const DepthStencilDescriptor& descriptor) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update render pipeline status
|
|
|
|
* Building a programmable pipeline involves an expensive evaluation of GPU state.
|
|
|
|
* So a new render pipeline object will be created only if it hasn't been created before.
|
|
|
|
* @param rt Specifies the render target.
|
|
|
|
* @param pipelineDescriptor Specifies the pipeline descriptor.
|
|
|
|
*/
|
|
|
|
virtual void updatePipelineState(const RenderTarget* rt, const PipelineDescriptor& descriptor) = 0;
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Fixed-function state
|
|
|
|
* @param x The x coordinate of the upper-left corner of the viewport.
|
|
|
|
* @param y The y coordinate of the upper-left corner of the viewport.
|
|
|
|
* @param w The width of the viewport, in pixels.
|
|
|
|
* @param h The height of the viewport, in pixels.
|
|
|
|
*/
|
|
|
|
virtual void setViewport(int x, int y, unsigned int w, unsigned int h) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fixed-function state
|
|
|
|
* @param mode Controls if primitives are culled when front facing, back facing, or not culled at all.
|
|
|
|
*/
|
|
|
|
virtual void setCullMode(CullMode mode) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fixed-function state
|
|
|
|
* @param winding The winding order of front-facing primitives.
|
|
|
|
*/
|
|
|
|
virtual void setWinding(Winding winding) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a global buffer for all vertex shaders at the given bind point index 0.
|
|
|
|
* @param buffer The vertex buffer to be setted in the buffer argument table.
|
|
|
|
*/
|
|
|
|
virtual void setVertexBuffer(Buffer* buffer) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set unifroms and textures
|
|
|
|
* @param programState A programState object that hold the uniform and texture data.
|
|
|
|
*/
|
|
|
|
virtual void setProgramState(ProgramState* programState) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set indexes when drawing primitives with index list
|
|
|
|
* @ buffer A buffer object that the device will read indexes from.
|
|
|
|
* @ see `drawElements(PrimitiveType primitiveType, IndexFormat indexType, unsigned int count, unsigned int offset)`
|
|
|
|
*/
|
|
|
|
virtual void setIndexBuffer(Buffer* buffer) = 0;
|
|
|
|
|
2023-07-28 14:13:01 +08:00
|
|
|
/**
|
|
|
|
* Set matrix tranform when drawing instances of the same model
|
|
|
|
* @ buffer A buffer object that the device will read matrices from.
|
|
|
|
*/
|
2023-07-31 10:03:24 +08:00
|
|
|
virtual void setInstanceBuffer(Buffer* buffer) = 0;
|
2023-07-28 14:13:01 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Draw primitives without an index list.
|
|
|
|
* @param primitiveType The type of primitives that elements are assembled into.
|
|
|
|
* @param start For each instance, the first index to draw
|
|
|
|
* @param count For each instance, the number of indexes to draw
|
|
|
|
* @see `drawElements(PrimitiveType primitiveType, IndexFormat indexType, unsigned int count, unsigned int offset)`
|
|
|
|
*/
|
2022-08-06 16:17:55 +08:00
|
|
|
virtual void drawArrays(PrimitiveType primitiveType,
|
|
|
|
std::size_t start,
|
|
|
|
std::size_t count,
|
|
|
|
bool wireframe = false) = 0;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Draw primitives with an index list.
|
|
|
|
* @param primitiveType The type of primitives that elements are assembled into.
|
|
|
|
* @param indexType The type if indexes, either 16 bit integer or 32 bit integer.
|
|
|
|
* @param count The number of indexes to read from the index buffer for each instance.
|
|
|
|
* @param offset Byte offset within indexBuffer to start reading indexes from.
|
|
|
|
* @see `setIndexBuffer(Buffer* buffer)`
|
|
|
|
* @see `drawArrays(PrimitiveType primitiveType, unsigned int start, unsigned int count)`
|
2021-12-25 10:04:45 +08:00
|
|
|
*/
|
|
|
|
virtual void drawElements(PrimitiveType primitiveType,
|
|
|
|
IndexFormat indexType,
|
|
|
|
std::size_t count,
|
2022-08-06 16:17:55 +08:00
|
|
|
std::size_t offset,
|
|
|
|
bool wireframe = false) = 0;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2023-07-28 14:13:01 +08:00
|
|
|
/**
|
|
|
|
* Draw primitives with an index list instanced.
|
|
|
|
* @param primitiveType The type of primitives that elements are assembled into.
|
|
|
|
* @param indexType The type if indexes, either 16 bit integer or 32 bit integer.
|
|
|
|
* @param count The number of indexes to read from the index buffer for each instance.
|
|
|
|
* @param offset Byte offset within indexBuffer to start reading indexes from.
|
|
|
|
* @param instance Count of instances to draw at once.
|
|
|
|
* @see `setIndexBuffer(Buffer* buffer)`
|
|
|
|
* @see `drawArrays(PrimitiveType primitiveType, unsigned int start, unsigned int count)`
|
|
|
|
*/
|
|
|
|
virtual void drawElementsInstanced(PrimitiveType primitiveType,
|
|
|
|
IndexFormat indexType,
|
|
|
|
std::size_t count,
|
|
|
|
std::size_t offset,
|
2023-07-31 10:03:24 +08:00
|
|
|
int instanceCount,
|
|
|
|
bool wireframe = false) = 0;
|
2023-07-28 14:13:01 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Do some resources release.
|
|
|
|
*/
|
|
|
|
virtual void endRenderPass() = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Present a drawable and commit a command buffer so it can be executed as soon as possible.
|
|
|
|
*/
|
|
|
|
virtual void endFrame() = 0;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Fixed-function state
|
|
|
|
* @param lineWidth Specifies the width of rasterized lines.
|
|
|
|
*/
|
|
|
|
virtual void setLineWidth(float lineWidth) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fixed-function state
|
|
|
|
* @param x, y Specifies the lower left corner of the scissor box
|
|
|
|
* @param wdith Specifies the width of the scissor box
|
|
|
|
* @param height Specifies the height of the scissor box
|
|
|
|
*/
|
|
|
|
virtual void setScissorRect(bool isEnabled, float x, float y, float width, float height) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a screen snapshot
|
|
|
|
* @param callback A callback to deal with screen snapshot image.
|
|
|
|
*/
|
2020-09-21 22:10:50 +08:00
|
|
|
virtual void readPixels(RenderTarget* rt, std::function<void(const PixelBufferDescriptor&)> callback) = 0;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
/**
|
|
|
|
* Update both front and back stencil reference value.
|
|
|
|
* @param value Specifies stencil reference value.
|
|
|
|
*/
|
|
|
|
void setStencilReferenceValue(unsigned int value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update stencil reference value.
|
|
|
|
* @param frontRef Specifies front stencil reference value.
|
|
|
|
* @param backRef Specifies back stencil reference value.
|
|
|
|
*/
|
|
|
|
void setStencilReferenceValue(unsigned int frontRef, unsigned int backRef);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
virtual ~CommandBuffer() = default;
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
|
|
unsigned int _stencilReferenceValueFront = 0; ///< front stencil reference value.
|
|
|
|
unsigned int _stencilReferenceValueBack = 0; ///< back stencil reference value.
|
2019-11-23 20:27:39 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
// end of _backend group
|
|
|
|
/// @}
|
2022-07-11 17:50:21 +08:00
|
|
|
NS_AX_BACKEND_END
|