Четно-нечетное правило - Even–odd rule

Кривая (вверху) заполняется по двум правилам: четно-нечетное правило (слева) и правило ненулевой обмотки (верно). В каждом случае стрелка показывает луч из точки P, выходящий за пределы кривой. В четно-нечетном случае луч пересекает две прямые, четное число; поэтому делается вывод, что P находится «вне» кривой. Согласно правилу ненулевой намотки, луч дважды пересекается по часовой стрелке, каждый из которых дает -1 для оценки намотки: поскольку сумма, -2, не равна нулю, P считается находящимся «внутри» кривой.

В четно-нечетное правило является алгоритм реализовано в векторном графическом ПО,[1] словно PostScript язык и Масштабируемая векторная графика (SVG), который определяет, как будет заливаться графическая фигура с более чем одним замкнутым контуром. в отличие от ненулевое правило Алгоритм этот алгоритм будет альтернативно раскрашивать и оставлять неокрашенные формы, определяемые вложенными замкнутыми контурами, независимо от их изгиба.

SVG определяет правило четности и нечетности, говоря:

Это правило определяет «внутренность» точки на холсте, рисуя луч из этой точки в бесконечность в любом направлении и подсчитывая количество сегментов пути от данной формы, которые пересекает луч. Если это число нечетное, точка находится внутри; если даже, то дело во внешнем.

Это правило действует во многих программах для векторной графики (например, От руки или же Иллюстратор ), где пересечение контура с самим собой вызывает странное заполнение форм.

На простой кривой правило четного – нечетного сводится к алгоритму решения для точка в многоугольнике проблема.

В SVG стандарт векторной графики компьютерной графики может быть настроен на использование правила четности-нечетности при рисовании многоугольников, хотя он использует ненулевое правило по умолчанию.[2]

Выполнение

Ниже приведен пример реализации в Python:[3]

def is_point_in_path(Икс: int, у: int, поли) -> bool:    "" "Определите, находится ли точка на пути.    Аргументы:      x - координаты x точки.      y - координаты y точки.      poly - список кортежей [(x, y), (x, y), ...]    Возврат:      Истинно, если точка находится на пути.    """    число = len(поли)    я = 0    j = число - 1    c = Ложь    за я в классифицировать(число):        если ((поли[я][1] > у) != (поли[j][1] > у)) и                 (Икс < поли[я][0] + (поли[j][0] - поли[я][0]) * (у - поли[я][1]) /                                  (поли[j][1] - поли[я][1])):            c = нет c        j = я    возвращаться c

Смотрите также

Рекомендации

  1. ^ Дж. Д. Фоли, А. ван Дам, С. К. Файнер и Дж. Ф. Хьюз. Компьютерная графика: принципы и практика. Серия системного программирования. Аддисон-Уэсли, Ридинг, 2-е издание, 1990 г.
  2. ^ [1], w3c.org, получено 28 марта 2019 г.
  3. ^ «PNPOLY - Точечное включение в тесте многоугольника - В. Р. Франклин (WRF)».

внешняя ссылка