// Copyright (C) 2013 Jérôme Leclercq // This file is part of the "Nazara Engine - Utility module" // For conditions of distribution and use, see copyright notice in Config.hpp #pragma once #ifndef NAZARA_INDEXBUFFER_HPP #define NAZARA_INDEXBUFFER_HPP #include #include #include #include class NzIndexBuffer; using NzIndexBufferConstRef = NzResourceRef; using NzIndexBufferRef = NzResourceRef; class NAZARA_API NzIndexBuffer : public NzResource { public: NzIndexBuffer(bool largeIndices, NzBuffer* buffer, unsigned int startOffset, unsigned int endOffset); NzIndexBuffer(bool largeIndices, unsigned int length, nzBufferStorage storage = nzBufferStorage_Software, nzBufferUsage usage = nzBufferUsage_Static); NzIndexBuffer(const NzIndexBuffer& vertexBuffer); ~NzIndexBuffer() = default; unsigned int ComputeCacheMissCount() const; bool Fill(const void* data, unsigned int offset, unsigned int size, bool forceDiscard = false); bool FillIndices(const void* data, unsigned int startIndex, unsigned int length, bool forceDiscard = false); NzBuffer* GetBuffer() const; unsigned int GetEndOffset() const; unsigned int GetIndexCount() const; unsigned int GetStride() const; unsigned int GetStartOffset() const; bool HasLargeIndices() const; bool IsHardware() const; void* Map(nzBufferAccess access, unsigned int offset = 0, unsigned int size = 0); void* Map(nzBufferAccess access, unsigned int offset = 0, unsigned int size = 0) const; void* MapIndices(nzBufferAccess access, unsigned int startVertex = 0, unsigned int length = 0); void* MapIndices(nzBufferAccess access, unsigned int startVertex = 0, unsigned int length = 0) const; void Optimize(); bool SetStorage(nzBufferStorage storage); void Unmap() const; private: NzBufferRef m_buffer; bool m_largeIndices; unsigned int m_endOffset; unsigned int m_indexCount; unsigned int m_startOffset; }; #endif // NAZARA_INDEXBUFFER_HPP