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