1 #ifndef _RRPRIMITIVEPACKET_HPP 2 #define _RRPRIMITIVEPACKET_HPP 3 /*------------------------------------------------------------------------- 4 * drawElements Quality Program Reference Renderer 5 * ----------------------------------------------- 6 * 7 * Copyright 2014 The Android Open Source Project 8 * 9 * Licensed under the Apache License, Version 2.0 (the "License"); 10 * you may not use this file except in compliance with the License. 11 * You may obtain a copy of the License at 12 * 13 * http://www.apache.org/licenses/LICENSE-2.0 14 * 15 * Unless required by applicable law or agreed to in writing, software 16 * distributed under the License is distributed on an "AS IS" BASIS, 17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 18 * See the License for the specific language governing permissions and 19 * limitations under the License. 20 * 21 *//*! 22 * \file 23 * \brief Primitive packet 24 *//*--------------------------------------------------------------------*/ 25 26 #include "rrDefs.hpp" 27 #include "rrGenericVector.hpp" 28 29 #include <vector> 30 31 namespace rr 32 { 33 34 struct VertexPacket; 35 class VertexPacketAllocator; 36 37 /*--------------------------------------------------------------------*//*! 38 * \brief Geometry packet 39 * 40 * Geometry packet contains inputs for geometry shading. 41 *//*--------------------------------------------------------------------*/ 42 struct PrimitivePacket 43 { 44 int primitiveIDIn; 45 const VertexPacket* vertices[6]; 46 } DE_WARN_UNUSED_TYPE; 47 48 /*--------------------------------------------------------------------*//*! 49 * \brief Geometry emitter 50 * 51 * Geometry emitter handles outputting of new vertices from geometry shader 52 *//*--------------------------------------------------------------------*/ 53 class GeometryEmitter 54 { 55 public: 56 GeometryEmitter (VertexPacketAllocator& vpalloc, size_t numVertices); 57 58 void EmitVertex (const tcu::Vec4& position, float pointSize, const GenericVec4* varyings, int primitiveID); 59 void EndPrimitive (void); 60 61 void moveEmittedTo (std::vector<VertexPacket*>&); 62 63 private: 64 GeometryEmitter (const GeometryEmitter&); 65 GeometryEmitter& operator= (const GeometryEmitter&); 66 67 std::vector<VertexPacket*> m_emitted; //!< NULL elements mean primitive end 68 VertexPacketAllocator& m_vpalloc; 69 size_t m_numEmitted; 70 size_t m_maxVertices; 71 72 } DE_WARN_UNUSED_TYPE; 73 74 } // rr 75 76 #endif // _RRPRIMITIVEPACKET_HPP 77