/* ** global-ibo.h ** ** This file is part of mkxp. ** ** Copyright (C) 2013 Jonas Kulla ** ** mkxp is free software: you can redistribute it and/or modify ** it under the terms of the GNU General Public License as published by ** the Free Software Foundation, either version 2 of the License, or ** (at your option) any later version. ** ** mkxp is distributed in the hope that it will be useful, ** but WITHOUT ANY WARRANTY; without even the implied warranty of ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ** GNU General Public License for more details. ** ** You should have received a copy of the GNU General Public License ** along with mkxp. If not, see . */ #ifndef GLOBALIBO_H #define GLOBALIBO_H #include "gl-util.h" #include #include #include #include typedef uint16_t index_t; #define INDEX_T_MAX std::numeric_limits::max() #define _GL_INDEX_TYPE GL_UNSIGNED_SHORT struct GlobalIBO { IBO::ID ibo; std::vector buffer; GlobalIBO() { ibo = IBO::gen(); } ~GlobalIBO() { IBO::del(ibo); } void ensureSize(size_t quadCount) { assert(quadCount*6 < INDEX_T_MAX); if (buffer.size() >= quadCount*6) return; size_t startInd = buffer.size() / 6; buffer.reserve(quadCount*6); for (size_t i = startInd; i < quadCount; ++i) { static const index_t indTemp[] = { 0, 1, 2, 2, 3, 0 }; for (size_t j = 0; j < 6; ++j) buffer.push_back(i * 4 + indTemp[j]); } IBO::bind(ibo); IBO::uploadData(buffer.size() * sizeof(index_t), dataPtr(buffer)); IBO::unbind(); } }; #endif // GLOBALIBO_H