2013-09-01 14:27:21 +00:00
|
|
|
/*
|
|
|
|
** global-ibo.h
|
|
|
|
**
|
|
|
|
** This file is part of mkxp.
|
|
|
|
**
|
|
|
|
** Copyright (C) 2013 Jonas Kulla <Nyocurio@gmail.com>
|
|
|
|
**
|
|
|
|
** 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 <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef GLOBALIBO_H
|
|
|
|
#define GLOBALIBO_H
|
|
|
|
|
2013-12-04 16:48:37 +00:00
|
|
|
#include "gl-util.h"
|
2013-12-26 19:18:33 +00:00
|
|
|
|
|
|
|
#include <vector>
|
2014-07-11 00:09:53 +00:00
|
|
|
#include <limits>
|
|
|
|
#include <assert.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2014-07-19 07:31:39 +00:00
|
|
|
typedef uint16_t index_t;
|
2014-07-11 00:09:53 +00:00
|
|
|
#define INDEX_T_MAX std::numeric_limits<index_t>::max()
|
2014-07-19 07:31:39 +00:00
|
|
|
#define _GL_INDEX_TYPE GL_UNSIGNED_SHORT
|
2013-09-01 14:27:21 +00:00
|
|
|
|
|
|
|
struct GlobalIBO
|
|
|
|
{
|
|
|
|
IBO::ID ibo;
|
2014-07-11 00:09:53 +00:00
|
|
|
std::vector<index_t> buffer;
|
2013-09-01 14:27:21 +00:00
|
|
|
|
|
|
|
GlobalIBO()
|
|
|
|
{
|
|
|
|
ibo = IBO::gen();
|
|
|
|
}
|
|
|
|
|
|
|
|
~GlobalIBO()
|
|
|
|
{
|
|
|
|
IBO::del(ibo);
|
|
|
|
}
|
|
|
|
|
2013-12-26 19:18:33 +00:00
|
|
|
void ensureSize(size_t quadCount)
|
2013-09-01 14:27:21 +00:00
|
|
|
{
|
2014-07-11 00:09:53 +00:00
|
|
|
assert(quadCount*6 < INDEX_T_MAX);
|
|
|
|
|
2013-09-01 14:27:21 +00:00
|
|
|
if (buffer.size() >= quadCount*6)
|
|
|
|
return;
|
|
|
|
|
2013-12-26 19:18:33 +00:00
|
|
|
size_t startInd = buffer.size() / 6;
|
2013-09-01 14:27:21 +00:00
|
|
|
buffer.reserve(quadCount*6);
|
|
|
|
|
2013-12-26 19:18:33 +00:00
|
|
|
for (size_t i = startInd; i < quadCount; ++i)
|
2013-09-01 14:27:21 +00:00
|
|
|
{
|
2014-07-11 00:09:53 +00:00
|
|
|
static const index_t indTemp[] = { 0, 1, 2, 2, 3, 0 };
|
2013-09-01 14:27:21 +00:00
|
|
|
|
2013-12-26 19:18:33 +00:00
|
|
|
for (size_t j = 0; j < 6; ++j)
|
|
|
|
buffer.push_back(i * 4 + indTemp[j]);
|
2013-09-01 14:27:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
IBO::bind(ibo);
|
2014-10-09 17:02:29 +00:00
|
|
|
IBO::uploadData(buffer.size() * sizeof(index_t), dataPtr(buffer));
|
2013-09-01 14:27:21 +00:00
|
|
|
IBO::unbind();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // GLOBALIBO_H
|