|
0 / 0 / 0
Регистрация: 08.12.2016
Сообщений: 3
|
||
Определить пересечение прямоугольника с фигурой08.12.2016, 18:04. Показов 752. Ответов 5
Метки нет (Все метки)
Приветствую. Моё задание - написать векторный графический редактор, текущая цель - сделать выделение фигур.
Выглядит это примерно . Мне нужно вывести формулы для каждой из представленных фигур таким образом, чтобы при касании линии фигуры она автоматически выделялась, при условии, что каждая из фигур ограничена прямоугольником, который не должен никак влиять на выделение. Для примера - эллипс создаётся по двум точкам - верхняя левая и нижняя правая; нужно сделать выделение таким образом, чтобы выделяя данную фигуру вне её границ - она не выделялась, даже если выделение лежит в области прямоугольника данной фигуры. Нужно составить проверку на то, лежит ли какой-либо фрагмент фигуры в прямоугольной области. Вторую неделю не могу составить данный алгоритм. Кратко о том, что имеется: - x0, y0, x1, y1 - координаты краёв прямоугольной области выделения - ax, ay, bx, by - координаты краёв фигуры - radius - радиус закругления у прямоугольника с закруглёнными краями - angle, count - угол поворота многоугольника и количество вершин в нём Для каких фигур: - Прямоугольник - Прямая линия - Закруглённый прямоугольник - Эллипс - Многоугольник Код пишется на языке Python с использованием библиотеки wxWidgets, исходник моего Благодарю за помощь.
0
|
||
| 08.12.2016, 18:04 | |
|
Ответы с готовыми решениями:
5
Какой фигурой является пересечение смежных AOB и BOC углов
Определить Вершины Прямоугольника |
|
1472 / 827 / 140
Регистрация: 12.10.2013
Сообщений: 5,456
|
||
| 09.12.2016, 11:40 | ||
|
0
|
||
|
0 / 0 / 0
Регистрация: 08.12.2016
Сообщений: 3
|
|
| 09.12.2016, 12:13 [ТС] | |
|
К сожалению, такой метод рассматривать нельзя, ибо
1) Помимо черного цвета существует еще палитра цветов 2) Кроме прозрачных фигур есть и залитые, и при наложении фигур это тоже нужно учитывать 3) Это сложный метод - требуется каким-либо образом определить цвет в точке, а в прямоугольном выделении этих точек достаточно, чтобы это затрачивало время на обработку.
0
|
|
|
1472 / 827 / 140
Регистрация: 12.10.2013
Сообщений: 5,456
|
||||
| 09.12.2016, 12:35 | ||||
|
Может змейки из примера нет \ убрать? Например все фигуры из отрезков, тогда анализ пересечений отрезков фигуры и отрезков прямоугольника выделения. 1)Или более грубый: принадлежность точки фигуры прямоугольнику выделения. 2)Еще более грубый и часто ошибочный: принадлежность точек краев фигуры прямоугольнику выделения.
0
|
||||
|
2903 / 1937 / 210
Регистрация: 05.06.2011
Сообщений: 5,714
|
|
| 09.12.2016, 16:33 | |
|
Ну дык: сначала (эвристика, чисто для скорости) смотрим, пересекается ли прямоугольник выделения с прямоугольником фигуры. Потом, если да, проверяем, лежат ли вершины прямоугольника выделения внутри фигуры.
0
|
|
|
0 / 0 / 0
Регистрация: 08.12.2016
Сообщений: 3
|
|
| 10.12.2016, 17:04 [ТС] | |
|
Для прямоугольника это просто определить, но помимо прямоугольника есть и фигуры с точками, не образкющими прямую вида x=n или y=n
0
|
|
| 10.12.2016, 17:04 | |
|
Помогаю со студенческими работами здесь
6
Как определить, лежит ли точка в площади прямоугольника? Пересечение отрезка и прямоугольника
Определить пересечение треугольников Определить функцию пересечение х у Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|