Здравствуйте, гость ( Вход | Регистрация )
|
Алексей1153 |
24.12.2010, 8:25
Сообщение
#1
|
![]() фрилансер ![]() ![]() ![]() ![]() ![]() ![]() Группа: Участник Сообщений: 2946 Регистрация: 19.6.2010 Из: Обливион Пользователь №: 1822 Спасибо сказали: 215 раз(а) Репутация: 34
|
Имеется вот такая задача: определить направление (по ЧС или против ЧС), в котором были введены вершины полигона. Собственно, нужено чётко различить знак, а само понятие направления тут довольно условно. Вводится полигон так: мышью щёлкаем по окну, вводя последовательно точки-вершины. Я по своим догадкам попытался решить так (но, видимо, неправильно): беру первую вершину в качестве начала всех радиус-векторов, затем считаю сумму векторных произведений для всех смежных пар векторов по очереди. Каждый вектор суммы имеет знак в зависимости от направления вращения первого вектора ко второму, а чтобы не учитывалась длина исходных векторов, вектор-результат для каждой пары делится на произведение их модулей - как-будто полигон состоит из единичных векторов (хотя, не полностью уверен, что правильно так поступать). Все значения векторных произведений суммирую, получается итоговый "момент", по его знаку различаю направление ввода полигона
алгоритм , похоже, неверный, так как правильно знак определяется через раз опять же, что делать с вершинами, совпавшими с первой. Сейчас я их просто игнорирую при суммировании вот код: Раскрывающийся текст Подскажите, кто знает, по какому алгоритму определить направление ввода полигона Сообщение отредактировал Алексей1153 - 24.12.2010, 8:25 |
|
|
|
![]() |
|
Алексей1153 |
24.12.2010, 20:50
Сообщение
#2
|
![]() фрилансер ![]() ![]() ![]() ![]() ![]() ![]() Группа: Участник Сообщений: 2946 Регистрация: 19.6.2010 Из: Обливион Пользователь №: 1822 Спасибо сказали: 215 раз(а) Репутация: 34
|
Вот получил ответ на одном из форумов:
>> "Математика и САПР", Москва, "Мир", 1988, стр. 15: Знак площади зависит от направления обхода контура. В правой системе координат положительный знак указывает направление против часовой стрелки. Площадь полигона A = ( S(xi*yi+1 - xi+1*yi) + xN*y1 - x1*yN)/2 Знак S означает "сумма по i от 1 до N-1". PS на первый и второй взгляд - работает Сообщение отредактировал Алексей1153 - 24.12.2010, 20:50 |
|
|
|
| Гость_Y_* |
16.3.2011, 14:08
Сообщение
#3
|
|
Гости |
Действительно работает! проверено для вогнутых и выпуклых полигонов!
Спасибо! Цитата(Алексей1153 @ 24.12.2010, 20:50) Link Вот получил ответ на одном из форумов: >> "Математика и САПР", Москва, "Мир", 1988, стр. 15: Знак площади зависит от направления обхода контура. В правой системе координат положительный знак указывает направление против часовой стрелки. Площадь полигона A = ( S(xi*yi+1 - xi+1*yi) + xN*y1 - x1*yN)/2 Знак S означает "сумма по i от 1 до N-1". PS на первый и второй взгляд - работает |
|
|
|
Алексей1153 Направление ввода полигона 24.12.2010, 8:25
Iron Bug для вогнутых многоугольников твой метод работать н... 24.12.2010, 10:16
Алексей1153 Iron Bug, арифметический центр тоже не подойдёт, я... 24.12.2010, 10:25
ufna Вопрос - а что есть "по часовой"? Я пони... 24.12.2010, 10:28
Алексей1153 ufna, это условно. Главное - знак различить. Напри... 24.12.2010, 10:33
ufna Вот изображение в приложении - так по ЧС или проти... 24.12.2010, 11:37
Алексей1153 это ЧС, но с самопересечением. Их быть не должно -... 24.12.2010, 13:37
Алексей1153 да, я тоже уже убедился в этом 17.3.2011, 10:46![]() ![]() ![]() |
|
Текстовая версия | Сейчас: 3.3.2026, 23:16 |