Добрый день! Есть массив точек, который образует непересекающийся многоугольник. Точки даны по порядку(добавляет пользователь), т.е. первая и вторая точки образуют сторону многоугольника. Это пол помещения. Нужно нарисовать вид сверху с перспективами стен:
Это пример для прямоугольника.
Рабочий код, который определяет точки со сдвигом в зависимости от высоты помещения:
Код AS3:
for (var j:uint = 0; j < length; j++) {
//находим текущую, прошлую и следующую точку
_currPoint = points[j];
if (j < points.length - 1)
_nextPoint = points[j + 1];
else
_nextPoint = points[0];
if (j == 0)
_prevPoint = points[points.length - 1];
else
_prevPoint = points[j - 1];
//находим отрезки, биссектрису
norm1 = _currPoint.subtract(_prevPoint);
norm1.normalize(1);
norm2 = _currPoint.subtract(_nextPoint);
norm2.normalize(1);
bisectrix = norm1.add(norm2);
//направление обхода
cw = (_currPoint.x - _prevPoint.x) * (_nextPoint.y - _currPoint.y) - (_currPoint.y - _prevPoint.y) * (_nextPoint.x - _currPoint.x) > 0;
if (!cw)
bisectrix.normalize(h);
else
bisectrix.normalize( -h);
//умножаем вектор биссектрисы на высоту стен
normRatio = h / Math.abs(bisectrix.x * norm1.y - bisectrix.y * norm1.x);
bisectrix.x *= normRatio;
bisectrix.y *= normRatio;
_pointsOffset.push(_currPoint.add(bisectrix));
}
Работает исправно и для сложных многоугольников (хотя такие вряд ли встретятся):
НО! Проблема 1: точки должны добавляться против часовой стрелки, если по часовой добавляешь - стены рисуются внутрь помещения и получается каламбур:
Проблема 2: если точки лежат на одной прямой - неправильно определяется биссектриса(на картинке ниже верхний отрезок многоугольника состоит из двух):
Буду благодарен за любую помощь как решить эти проблемы.
Код родился
из этой темы.