mirror of
https://github.com/minetest/minetestmapper.git
synced 2025-01-12 03:00:27 +01:00
Finish refactor
This commit is contained in:
parent
b6ad40feb9
commit
0d9ed247f9
@ -439,7 +439,7 @@ void TileGenerator::renderMapBlock(const BlockDecoder &blk, const BlockPos &pos)
|
|||||||
|
|
||||||
// do this afterwards so we can record height values
|
// do this afterwards so we can record height values
|
||||||
// inside transparent nodes (water) too
|
// inside transparent nodes (water) too
|
||||||
if (m_readInfo.get(x, z)) {
|
if (!m_readInfo.get(x, z)) {
|
||||||
m_blockPixelAttributes.attribute(15 - z, xBegin + x).height = pos.y * 16 + y;
|
m_blockPixelAttributes.attribute(15 - z, xBegin + x).height = pos.y * 16 + y;
|
||||||
m_readInfo.set(x, z);
|
m_readInfo.set(x, z);
|
||||||
}
|
}
|
||||||
@ -509,6 +509,8 @@ void TileGenerator::renderShading(int zPos)
|
|||||||
|
|
||||||
void TileGenerator::renderScale()
|
void TileGenerator::renderScale()
|
||||||
{
|
{
|
||||||
|
const int scale_d = 40; // see createImage()
|
||||||
|
|
||||||
if (m_scales & SCALE_TOP) {
|
if (m_scales & SCALE_TOP) {
|
||||||
m_image->drawText(24, 0, "X", m_scaleColor);
|
m_image->drawText(24, 0, "X", m_scaleColor);
|
||||||
for (int i = (m_xMin / 4) * 4; i <= m_xMax; i += 4) {
|
for (int i = (m_xMin / 4) * 4; i <= m_xMax; i += 4) {
|
||||||
@ -538,11 +540,14 @@ void TileGenerator::renderScale()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (m_scales & SCALE_BOTTOM) {
|
if (m_scales & SCALE_BOTTOM) {
|
||||||
|
int xPos = m_xBorder + m_mapWidth*m_zoom - 24 - 8,
|
||||||
|
yPos = m_yBorder + m_mapHeight*m_zoom + scale_d - 12;
|
||||||
|
m_image->drawText(xPos, yPos, "X", m_scaleColor);
|
||||||
for (int i = (m_xMin / 4) * 4; i <= m_xMax; i += 4) {
|
for (int i = (m_xMin / 4) * 4; i <= m_xMax; i += 4) {
|
||||||
stringstream buf;
|
stringstream buf;
|
||||||
buf << i * 16;
|
buf << i * 16;
|
||||||
|
|
||||||
int xPos = getImageX(i * 16, true),
|
xPos = getImageX(i * 16, true);
|
||||||
yPos = m_yBorder + m_mapHeight*m_zoom;
|
yPos = m_yBorder + m_mapHeight*m_zoom;
|
||||||
if (xPos >= 0) {
|
if (xPos >= 0) {
|
||||||
m_image->drawText(xPos + 2, yPos, buf.str(), m_scaleColor);
|
m_image->drawText(xPos + 2, yPos, buf.str(), m_scaleColor);
|
||||||
@ -552,11 +557,14 @@ void TileGenerator::renderScale()
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (m_scales & SCALE_RIGHT) {
|
if (m_scales & SCALE_RIGHT) {
|
||||||
|
int xPos = m_xBorder + m_mapWidth*m_zoom + scale_d - 2 - 8,
|
||||||
|
yPos = m_yBorder + m_mapHeight*m_zoom - 24 - 12;
|
||||||
|
m_image->drawText(xPos, yPos, "Z", m_scaleColor);
|
||||||
for (int i = (m_zMax / 4) * 4; i >= m_zMin; i -= 4) {
|
for (int i = (m_zMax / 4) * 4; i >= m_zMin; i -= 4) {
|
||||||
stringstream buf;
|
stringstream buf;
|
||||||
buf << i * 16;
|
buf << i * 16;
|
||||||
|
|
||||||
int xPos = m_xBorder + m_mapWidth*m_zoom,
|
xPos = m_xBorder + m_mapWidth*m_zoom;
|
||||||
yPos = getImageY(i * 16 + 1, true);
|
yPos = getImageY(i * 16 + 1, true);
|
||||||
if (yPos >= 0) {
|
if (yPos >= 0) {
|
||||||
m_image->drawText(xPos + 2, yPos, buf.str(), m_scaleColor);
|
m_image->drawText(xPos + 2, yPos, buf.str(), m_scaleColor);
|
||||||
@ -581,11 +589,14 @@ void TileGenerator::renderPlayers(const std::string &inputPath)
|
|||||||
if (player->x < m_xMin * 16 || player->x > m_xMax * 16 ||
|
if (player->x < m_xMin * 16 || player->x > m_xMax * 16 ||
|
||||||
player->z < m_zMin * 16 || player->z > m_zMax * 16)
|
player->z < m_zMin * 16 || player->z > m_zMax * 16)
|
||||||
continue;
|
continue;
|
||||||
|
if (player->y < m_yMin || player->y > m_yMax)
|
||||||
|
continue;
|
||||||
int imageX = getImageX(player->x, true),
|
int imageX = getImageX(player->x, true),
|
||||||
imageY = getImageY(player->z, true);
|
imageY = getImageY(player->z, true);
|
||||||
|
|
||||||
m_image->drawCircle(imageX, imageY, 5, m_playerColor);
|
m_image->drawFilledRect(imageX - 1, imageY, 3, 1, m_playerColor);
|
||||||
m_image->drawText(imageX + 2, imageY + 2, player->name, m_playerColor);
|
m_image->drawFilledRect(imageX, imageY - 1, 1, 3, m_playerColor);
|
||||||
|
m_image->drawText(imageX + 2, imageY, player->name, m_playerColor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -609,12 +620,11 @@ void TileGenerator::writeImage(const std::string &output)
|
|||||||
|
|
||||||
void TileGenerator::printUnknown()
|
void TileGenerator::printUnknown()
|
||||||
{
|
{
|
||||||
if (m_unknownNodes.size() > 0) {
|
if (m_unknownNodes.size() == 0)
|
||||||
|
return;
|
||||||
std::cerr << "Unknown nodes:" << std::endl;
|
std::cerr << "Unknown nodes:" << std::endl;
|
||||||
for (NameSet::iterator node = m_unknownNodes.begin(); node != m_unknownNodes.end(); ++node) {
|
for (NameSet::iterator node = m_unknownNodes.begin(); node != m_unknownNodes.end(); ++node)
|
||||||
std::cerr << *node << std::endl;
|
std::cerr << "\t" << *node << std::endl;
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
inline int TileGenerator::getImageX(int val, bool absolute) const
|
inline int TileGenerator::getImageX(int val, bool absolute) const
|
||||||
|
Loading…
Reference in New Issue
Block a user