Студопедия Главная Случайная страница Обратная связь

Разделы: Автомобили Астрономия Биология География Дом и сад Другие языки Другое Информатика История Культура Литература Логика Математика Медицина Металлургия Механика Образование Охрана труда Педагогика Политика Право Психология Религия Риторика Социология Спорт Строительство Технология Туризм Физика Философия Финансы Химия Черчение Экология Экономика Электроника

Клиппирование многоугольников





От задачи отсечения отрезков можно перейти к более сложной: клиппирование произвольных многоугольников. Если многоугольник невыпуклый, то в результате пересечения даже с прямоугольным окном может получиться несколько не связанных между собой фигур, как это показано на рис. 6.8.

Рис. 6.8. Отсечение невыпуклого многоугольника

Когда стоит задача штрихования замкнутой области одновременно с задачей отсечения, то важно правильно определить принадлежность вновь полученных фигур внутренней или внешней части исходного многоугольника. Пусть исходный многоугольник задан упорядоченным списком вершин , соответствующих ребрам . Для отсечения такого многоугольника прямоугольным окном можно применить алгоритм, предложенный Сазерлендом и Ходжменом. Идея его заключается в последовательном отсечении части многоугольника прямыми, соответствующими сторонам окна. Результатом его работы является упорядоченный список вершин, лежащих в видимой части окна. На каждом шаге алгоритма образуется некоторая промежуточная фигура, также представленная упорядоченным списком вершин и ребер. Пример таких последовательных отсечений показан на рис. 6.9. В процессе отсечения последовательно обходится список вершин, причем каждая очередная точка за исключением первой рассматривается как конечная точка ребра, начальной точкой которого является предшествующая точка из списка. Порядок, в котором рассматриваются стороны окна, не имеет значения. В процессе обхода формируется список новых вершин многоугольника.

Рис. 6.9. Последовательные шаги клиппирования произвольного многоугольника

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

Для анализируемого ребра возможны четыре случая расположения относительно окна.

  1. Ребро полностью видимо. Очередная точка заносится в список новых вершин (предыдущая уже должна находиться в этом списке, поскольку ребро полностью видимо).
  2. Ребро полностью невидимо. Никаких действий не производится.
  3. Ребро выходит из области. Находится точка пересечения ребра со стороной окна и заносится в список новых ребер.
  4. Ребро входит в область. Также отыскивается точка пересечения со стороной окна и заносится в список новых вершин. Конечная точка тоже заносится в список новых вершин.

В этом алгоритме постоянно приходится определять видимость точки по отношению к конкретному ребру отсекающего окна. Окно также можно задать в виде упорядоченного списка вершин. Если обход вершин окна осуществляется по часовой стрелке, то его внутренняя область будет расположена по правую сторону от границы. При этом расположение точки относительно прямой, которой принадлежит ребро, можно устанавливать различными способами:

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

  1. Для произвольной внутренней точки окна вычисляется значение , а также для точки вычисляется . Если числа и имеют одинаковый знак, то точка является видимой.

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

Вопросы и упражнения

  1. Что такое клиппирование?
  2. Если концы отрезков имеют коды 1000 и 0100, сколько сторон окна он может пересекать?
  3. При каком значении кода одного из концов отрезка он обязательно будет частично видимым?
  4. Если оба конца отрезка лежат вне окна, то при каких кодах концов он может проходить вдоль диагонали окна?
  5. Какой из алгоритмов отсечения отрезков эффективнее: приведенный в блок-схеме 5.3 или основанный на делении отрезка пополам?
  6. С помощью какого условия можно определить принадлежность точки выпуклому многоугольнику?
  7. Будет ли это условие применимо в случае произвольного многоугольника? (подтвердите свой ответ примерами).
  8. Какие случаи расположения ребра относительно окна рассматриваются в алгоритме клиппирования произвольного многоугольника?







Дата добавления: 2015-10-01; просмотров: 475. Нарушение авторских прав; Мы поможем в написании вашей работы!




Вычисление основной дактилоскопической формулы Вычислением основной дактоформулы обычно занимается следователь. Для этого все десять пальцев разбиваются на пять пар...


Расчетные и графические задания Равновесный объем - это объем, определяемый равенством спроса и предложения...


Кардиналистский и ординалистский подходы Кардиналистский (количественный подход) к анализу полезности основан на представлении о возможности измерения различных благ в условных единицах полезности...


Обзор компонентов Multisim Компоненты – это основа любой схемы, это все элементы, из которых она состоит. Multisim оперирует с двумя категориями...

Эндоскопическая диагностика язвенной болезни желудка, гастрита, опухоли Хронический гастрит - понятие клинико-анатомическое, характеризующееся определенными патоморфологическими изменениями слизистой оболочки желудка - неспецифическим воспалительным процессом...

Признаки классификации безопасности Можно выделить следующие признаки классификации безопасности. 1. По признаку масштабности принято различать следующие относительно самостоятельные геополитические уровни и виды безопасности. 1.1. Международная безопасность (глобальная и...

Прием и регистрация больных Пути госпитализации больных в стационар могут быть различны. В цен­тральное приемное отделение больные могут быть доставлены: 1) машиной скорой медицинской помощи в случае возникновения остро­го или обострения хронического заболевания...

Понятие о синдроме нарушения бронхиальной проходимости и его клинические проявления Синдром нарушения бронхиальной проходимости (бронхообструктивный синдром) – это патологическое состояние...

Опухоли яичников в детском и подростковом возрасте Опухоли яичников занимают первое место в структуре опухолей половой системы у девочек и встречаются в возрасте 10 – 16 лет и в период полового созревания...

Способы тактических действий при проведении специальных операций Специальные операции проводятся с применением следующих основных тактических способов действий: охрана...

Studopedia.info - Студопедия - 2014-2025 год . (0.012 сек.) русская версия | украинская версия