Files
scummvm-cursorfix/engines/ultima/nuvie/misc/u6_line_walker.cpp
2026-02-02 04:50:13 +01:00

96 lines
2.2 KiB
C++

/* ScummVM - Graphic Adventure Engine
*
* ScummVM is the legal property of its developers, whose names
* are too numerous to list here. Please refer to the COPYRIGHT
* file distributed with this source distribution.
*
* This program 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 3 of the License, or
* (at your option) any later version.
*
* This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
#include "ultima/nuvie/misc/u6_line_walker.h"
namespace Ultima {
namespace Nuvie {
U6LineWalker::U6LineWalker(uint32 sx, uint32 sy, uint32 ex, uint32 ey)
: start_x(sx), start_y(sy), end_x(ex), end_y(ey), cur_x(sx), cur_y(sy), cur_step(0) {
sint32 delta_x = end_x - start_x;
sint32 delta_y = end_y - start_y;
yoffset[0] = 0;
if (delta_x >= 0) {
xoffset[0] = 1;
xoffset[1] = 1;
} else {
delta_x = -delta_x;
xoffset[0] = -1;
xoffset[1] = -1;
}
if (delta_y >= 0) {
yoffset[1] = 1;
} else {
delta_y = -delta_y;
yoffset[1] = -1;
}
if (delta_x < delta_y) {
sint32 tmp_var = delta_x;
delta_x = delta_y;
delta_y = tmp_var;
yoffset[0] = yoffset[1];
xoffset[1] = xoffset[0];
xoffset[0] = 0;
}
max_length = delta_x;
line_counter = delta_y + delta_y - delta_x;
line_inc[0] = delta_y + delta_y;
line_inc[1] = (delta_y - delta_x) * 2;
}
U6LineWalker::~U6LineWalker() {
// TODO Auto-generated destructor stub
}
bool U6LineWalker::step() {
if (cur_step >= max_length)
return false;
uint8 idx = line_counter < 0 ? 0 : 1;
line_counter += line_inc[idx];
cur_x += xoffset[idx];
cur_y += yoffset[idx];
cur_step++;
return true;
}
bool U6LineWalker::next(uint32 *x, uint32 *y) {
bool ret = step();
*x = cur_x;
*y = cur_y;
return ret;
}
} // End of namespace Nuvie
} // End of namespace Ultima