Определение площади по описывающим точкам

Программирование на Visual Basic, главный форум. Обсуждение тем программирования на VB 1—6.
Даже если вы плохо разбираетесь в VB и программировании вообще — тут вам помогут. В разумных пределах, конечно.
Правила форума
Темы, в которых будет сначала написано «что нужно сделать», а затем просьба «помогите», будут закрыты.
Читайте требования к создаваемым темам.
AjaxVS
Постоялец
Постоялец
 
Сообщения: 506
Зарегистрирован: 01.12.2004 (Ср) 13:12
Откуда: Donetsk, Battle.Net

Определение площади по описывающим точкам

Сообщение AjaxVS » 26.03.2007 (Пн) 19:00

Приветствую.

Подкинули мне задачку, мне показалось, интересную.
Вся сложность заключается в вопросе:

как найти площадь геометрического объекта, зная координаты описывающих его точек?

(см. рисунок)

Ничего лучше создания полигона (CreatePolygonRgn) я пока не придумал.
Т.е. закрасить определенным цветом (не встречающимся на рисунке) это тело, а потом циклически пройтись по рисунку, считая количество пикселей того самого цвета - сумма их и будет площадью.

Но слишком громоздко это.. Нет ли ничего попроще?
С удовольствием выслушаю любые идеи.

Изображение

GSerg
Шаман
Шаман
 
Сообщения: 14286
Зарегистрирован: 14.12.2002 (Сб) 5:25
Откуда: Магадан

Сообщение GSerg » 26.03.2007 (Пн) 19:12

Площадь произвольных многоугольников ищется путём разбиения оных на треугольники.
Как только вы переберёте все варианты решения и не найдёте нужного, тут же обнаружится решение, простое и очевидное для всех, кроме вас

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 26.03.2007 (Пн) 20:15

И всё же, площадь произвольных (в т.ч. невыпуклых) многоугольников обычно ищется путём разбиения оных на трапеции. Бить невыпуклые многоугольники на треугольники тяжелее.

http://algolist.manual.ru/maths/geom/polygon/area.php
Изображение

AjaxVS
Постоялец
Постоялец
 
Сообщения: 506
Зарегистрирован: 01.12.2004 (Ср) 13:12
Откуда: Donetsk, Battle.Net

Сообщение AjaxVS » 26.03.2007 (Пн) 21:05

Хм.. По идее, если взять самую верхнюю точку, и от нее циклически по всем остальным (в парах) точкам строить треугольники, то проблем не будет в любом случае.. Хоть он выпуклый, хоть невыпуклый.
Правильно?

GSerg
Шаман
Шаман
 
Сообщения: 14286
Зарегистрирован: 14.12.2002 (Сб) 5:25
Откуда: Магадан

Сообщение GSerg » 26.03.2007 (Пн) 21:15

Неправильно.
Как только вы переберёте все варианты решения и не найдёте нужного, тут же обнаружится решение, простое и очевидное для всех, кроме вас

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 26.03.2007 (Пн) 21:20

Контрпример:
Код: Выделить всё
|\/|
|__|
Изображение

Amed
Алфизик
Алфизик
 
Сообщения: 5346
Зарегистрирован: 09.03.2003 (Вс) 9:26

Сообщение Amed » 26.03.2007 (Пн) 21:29

Неправильно... попробуй применить свой метод для такой фигуры
Изображение
Вложения
test.jpg
test.jpg (6.93 Кб) Просмотров: 539

AjaxVS
Постоялец
Постоялец
 
Сообщения: 506
Зарегистрирован: 01.12.2004 (Ср) 13:12
Откуда: Donetsk, Battle.Net

Сообщение AjaxVS » 26.03.2007 (Пн) 22:20

Мда. Против науки не попрешь :D
Ну да я и не против, проще этого:
Изображение
вряд ли что-то можно выдумать.
thx.

Viper
Артефакт VBStreets
Артефакт VBStreets
Аватара пользователя
 
Сообщения: 4394
Зарегистрирован: 12.04.2005 (Вт) 17:50
Откуда: Н.Новгород

Сообщение Viper » 27.03.2007 (Вт) 6:55

Только учти, что площадь считанная по этой формуле может получиться отрицательной, если вершины обходить по часовой стрелке.
Весь мир матрица, а мы в нем потоки байтов!

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 27.03.2007 (Вт) 10:01

Не "может", а гарантированно получится.

Один из способов узнать направление обхода, задаваемое набором точек -- посчитать по этой формуле площадь, и посмотреть её знак.
Изображение

Viper
Артефакт VBStreets
Артефакт VBStreets
Аватара пользователя
 
Сообщения: 4394
Зарегистрирован: 12.04.2005 (Вт) 17:50
Откуда: Н.Новгород

Сообщение Viper » 27.03.2007 (Вт) 10:27

Что-то мутно я выразился. Естественно, что при обходе по часовой стрелке значение будет отрицательным, а при обходе против часовой стрелки положительным. и до кучи получим ноль при расположении точек на одной прямой.
Весь мир матрица, а мы в нем потоки байтов!

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 27.03.2007 (Вт) 10:44

!Viper! писал(а):и до кучи получим ноль при расположении точек на одной прямой.

Не только: есть куча других фигур нулевой площади.
Изображение

Vi
Постоялец
Постоялец
 
Сообщения: 739
Зарегистрирован: 25.01.2002 (Пт) 11:03
Откуда: Россия, Ижевск

Сообщение Vi » 28.03.2007 (Ср) 5:55

!Viper! писал(а):Только учти, что площадь считанная по этой формуле может получиться отрицательной, если вершины обходить по часовой стрелке.

А что модуль числа имеет отрицательные значения?
Vita
Выше головы не прыгнешь, ниже земли не упадешь, дальше границы не убежишь! (с) КВН

Viper
Артефакт VBStreets
Артефакт VBStreets
Аватара пользователя
 
Сообщения: 4394
Зарегистрирован: 12.04.2005 (Вт) 17:50
Откуда: Н.Новгород

Сообщение Viper » 28.03.2007 (Ср) 7:19

Нды... не заметил, что в формуле приведенной AjaxVS уже стоят символы модуля... :oops: быват... Сработала ассоциация с формулой из математического справочника, где она без этих скобок и идут упоминания о порядке обхода вершин.
Весь мир матрица, а мы в нем потоки байтов!


Вернуться в Visual Basic 1–6

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 67

    TopList  
cron