leocad/common/tr.cpp

131 lines
3 KiB
C++
Raw Normal View History

#include "lc_global.h"
2011-09-07 23:06:51 +02:00
#include "tr.h"
2017-02-11 18:46:21 +01:00
#include "lc_math.h"
2011-09-07 23:06:51 +02:00
TiledRender::TiledRender()
{
2017-02-11 18:46:21 +01:00
mTileWidth = 256;
mTileHeight = 256;
mCurrentTile = -1;
2011-09-07 23:06:51 +02:00
}
TiledRender::~TiledRender()
{
}
2017-02-11 18:46:21 +01:00
void TiledRender::TileSize(int width, int height)
2011-09-07 23:06:51 +02:00
{
2017-02-11 18:46:21 +01:00
mTileWidth = width;
mTileHeight = height;
2011-09-07 23:06:51 +02:00
}
void TiledRender::ImageSize(int width, int height)
{
2017-02-11 18:46:21 +01:00
mImageWidth = width;
mImageHeight = height;
2011-09-07 23:06:51 +02:00
}
void TiledRender::Ortho(double left, double right, double bottom, double top, double zNear, double zFar)
{
2017-02-11 18:46:21 +01:00
if (mCurrentTile < 0)
2011-09-07 23:06:51 +02:00
{
2017-02-11 18:46:21 +01:00
mPerspective = false;
mLeft = left;
mRight = right;
mBottom = bottom;
mTop = top;
mNear = zNear;
mFar = zFar;
2011-09-07 23:06:51 +02:00
}
}
void TiledRender::Frustum(double left, double right, double bottom, double top, double zNear, double zFar)
{
2017-02-11 18:46:21 +01:00
if (mCurrentTile < 0)
2011-09-07 23:06:51 +02:00
{
2017-02-11 18:46:21 +01:00
mPerspective = true;
mLeft = left;
mRight = right;
mBottom = bottom;
mTop = top;
mNear = zNear;
mFar = zFar;
2011-09-07 23:06:51 +02:00
}
}
2017-02-11 18:46:21 +01:00
void TiledRender::Perspective(double fovy, double aspect, double zNear, double zFar)
2011-09-07 23:06:51 +02:00
{
double xmin, xmax, ymin, ymax;
ymax = zNear * tan(fovy * 3.14159265 / 360.0);
ymin = -ymax;
xmin = ymin * aspect;
xmax = ymax * aspect;
Frustum(xmin, xmax, ymin, ymax, zNear, zFar);
}
2017-02-11 18:46:21 +01:00
lcMatrix44 TiledRender::BeginTile()
2011-09-07 23:06:51 +02:00
{
2017-02-11 18:46:21 +01:00
int tileWidth, tileHeight;
2011-09-07 23:06:51 +02:00
double left, right, bottom, top;
2017-02-11 18:46:21 +01:00
if (mCurrentTile <= 0)
2011-09-07 23:06:51 +02:00
{
2017-02-11 18:46:21 +01:00
mColumns = (mImageWidth + mTileWidth - 1) / mTileWidth;
mRows = (mImageHeight + mTileHeight - 1) / mTileHeight;
mCurrentTile = 0;
2011-09-07 23:06:51 +02:00
// Save user's viewport, will be restored after last tile rendered
2017-02-11 18:46:21 +01:00
glGetIntegerv(GL_VIEWPORT, mViewportSave);
2011-09-07 23:06:51 +02:00
}
2017-02-11 18:46:21 +01:00
2011-09-07 23:06:51 +02:00
// which tile (by row and column) we're about to render
2017-02-11 18:46:21 +01:00
mCurrentRow = mCurrentTile / mColumns;
mCurrentColumn = mCurrentTile % mColumns;
2011-09-07 23:06:51 +02:00
// Compute actual size of this tile with border
2017-02-11 18:46:21 +01:00
if (mCurrentRow < mRows - 1)
tileHeight = mTileHeight;
2011-09-07 23:06:51 +02:00
else
2017-02-11 18:46:21 +01:00
tileHeight = mImageHeight - (mRows - 1) * (mTileHeight);
if (mCurrentColumn < mColumns - 1)
tileWidth = mTileWidth;
2011-09-07 23:06:51 +02:00
else
2017-02-11 18:46:21 +01:00
tileWidth = mImageWidth - (mColumns - 1) * (mTileWidth);
2011-09-07 23:06:51 +02:00
// Save tile size, with border
2017-02-11 18:46:21 +01:00
mCurrentTileWidth = tileWidth;
mCurrentTileHeight = tileHeight;
2011-09-07 23:06:51 +02:00
glViewport(0, 0, tileWidth, tileHeight); // tile size including border
2017-02-11 18:46:21 +01:00
2011-09-07 23:06:51 +02:00
// compute projection parameters
2017-02-11 18:46:21 +01:00
left = mLeft + (mRight - mLeft) * (mCurrentColumn * mTileWidth) / mImageWidth;
right = left + (mRight - mLeft) * tileWidth / mImageWidth;
bottom = mBottom + (mTop - mBottom) * (mCurrentRow * mTileHeight) / mImageHeight;
top = bottom + (mTop - mBottom) * tileHeight / mImageHeight;
if (mPerspective)
return lcMatrix44Frustum(left, right, bottom, top, mNear, mFar);
2011-09-07 23:06:51 +02:00
else
2017-02-11 18:46:21 +01:00
return lcMatrix44Ortho(left, right, bottom, top, mNear, mFar);
2011-09-07 23:06:51 +02:00
}
int TiledRender::EndTile()
{
// be sure OpenGL rendering is finished
glFlush();
2017-02-11 18:46:21 +01:00
2011-09-07 23:06:51 +02:00
// increment tile counter, return 1 if more tiles left to render
2017-02-11 18:46:21 +01:00
mCurrentTile++;
if (mCurrentTile >= mRows * mColumns)
2011-09-07 23:06:51 +02:00
{
// restore user's viewport
2017-02-11 18:46:21 +01:00
glViewport(mViewportSave[0], mViewportSave[1], mViewportSave[2], mViewportSave[3]);
mCurrentTile = -1; // all done
2011-09-07 23:06:51 +02:00
return 0;
}
else
return 1;
}