2014-07-27 14:58:30 +02:00
|
|
|
// Copyright 2014 Citra Emulator Project
|
2014-12-17 06:38:14 +01:00
|
|
|
// Licensed under GPLv2 or any later version
|
2014-07-27 14:58:30 +02:00
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2014-08-17 17:44:55 +02:00
|
|
|
#include <functional>
|
2017-01-28 21:34:31 +01:00
|
|
|
#include "video_core/regs_pipeline.h"
|
2019-12-22 17:06:26 +01:00
|
|
|
namespace boost::serialization { class access; }
|
2014-07-27 14:58:30 +02:00
|
|
|
|
2014-08-17 17:44:55 +02:00
|
|
|
namespace Pica {
|
2014-07-27 14:58:30 +02:00
|
|
|
|
2014-08-17 17:44:55 +02:00
|
|
|
/*
|
|
|
|
* Utility class to build triangles from a series of vertices,
|
|
|
|
* according to a given triangle topology.
|
|
|
|
*/
|
2016-09-18 02:38:01 +02:00
|
|
|
template <typename VertexType>
|
2014-08-17 17:44:55 +02:00
|
|
|
struct PrimitiveAssembler {
|
2017-01-28 03:10:54 +01:00
|
|
|
using TriangleHandler =
|
|
|
|
std::function<void(const VertexType& v0, const VertexType& v1, const VertexType& v2)>;
|
2014-08-17 17:44:55 +02:00
|
|
|
|
2017-01-28 21:34:31 +01:00
|
|
|
PrimitiveAssembler(
|
|
|
|
PipelineRegs::TriangleTopology topology = PipelineRegs::TriangleTopology::List);
|
2014-08-17 17:44:55 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Queues a vertex, builds primitives from the vertex queue according to the given
|
|
|
|
* triangle topology, and calls triangle_handler for each generated primitive.
|
|
|
|
* NOTE: We could specify the triangle handler in the constructor, but this way we can
|
|
|
|
* keep event and handler code next to each other.
|
|
|
|
*/
|
2017-01-28 03:10:54 +01:00
|
|
|
void SubmitVertex(const VertexType& vtx, TriangleHandler triangle_handler);
|
2014-08-17 17:44:55 +02:00
|
|
|
|
2017-07-26 14:07:13 +02:00
|
|
|
/**
|
|
|
|
* Invert the vertex order of the next triangle. Called by geometry shader emitter.
|
|
|
|
* This only takes effect for TriangleTopology::Shader.
|
|
|
|
*/
|
|
|
|
void SetWinding();
|
|
|
|
|
2016-03-03 04:16:38 +01:00
|
|
|
/**
|
|
|
|
* Resets the internal state of the PrimitiveAssembler.
|
|
|
|
*/
|
|
|
|
void Reset();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reconfigures the PrimitiveAssembler to use a different triangle topology.
|
|
|
|
*/
|
2017-01-28 21:34:31 +01:00
|
|
|
void Reconfigure(PipelineRegs::TriangleTopology topology);
|
2016-03-03 04:16:38 +01:00
|
|
|
|
2017-12-27 14:02:34 +01:00
|
|
|
/**
|
2018-05-11 15:42:29 +02:00
|
|
|
* Returns whether the PrimitiveAssembler has an empty internal buffer.
|
2017-12-27 14:02:34 +01:00
|
|
|
*/
|
|
|
|
bool IsEmpty() const;
|
|
|
|
|
|
|
|
/**
|
2018-05-11 15:42:29 +02:00
|
|
|
* Returns the current topology.
|
2017-12-27 14:02:34 +01:00
|
|
|
*/
|
|
|
|
PipelineRegs::TriangleTopology GetTopology() const;
|
|
|
|
|
2014-08-17 17:44:55 +02:00
|
|
|
private:
|
2017-01-28 21:34:31 +01:00
|
|
|
PipelineRegs::TriangleTopology topology;
|
2014-08-17 17:44:55 +02:00
|
|
|
|
|
|
|
int buffer_index;
|
|
|
|
VertexType buffer[2];
|
2014-12-07 00:26:48 +01:00
|
|
|
bool strip_ready = false;
|
2017-07-26 14:07:13 +02:00
|
|
|
bool winding = false;
|
2019-12-22 17:06:26 +01:00
|
|
|
|
|
|
|
template <class Archive>
|
|
|
|
void serialize(Archive& ar, const unsigned int version)
|
|
|
|
{
|
|
|
|
ar & topology;
|
|
|
|
ar & buffer_index;
|
|
|
|
ar & buffer;
|
|
|
|
ar & strip_ready;
|
|
|
|
ar & winding;
|
|
|
|
}
|
|
|
|
friend class boost::serialization::access;
|
2014-08-17 17:44:55 +02:00
|
|
|
};
|
2014-07-27 14:58:30 +02:00
|
|
|
|
2018-03-09 18:54:43 +01:00
|
|
|
} // namespace Pica
|