Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/18: Рейтинг темы: голосов - 18, средняя оценка - 4.83
0 / 0 / 1
Регистрация: 21.10.2012
Сообщений: 51

Разбиение фигуры с тупыми углами на произвольным прямоугольники

27.04.2017, 08:32. Показов 3568. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте форумчане, помогите придумать алгоритм, для разбиения геометрической фигуры произвольной формы (развернутая гофрокоробка) с углами в 90 градусов на произвольные прямоугольники (не обязательно с одинаковыми сторонами). Пример объекта и способа его разбиения в закрепленном изображении.

Имеется лист, содержащий точки ГО:
C#
1
List<Point> points = new List<Point>();
Необходимо на выходе получить Лист, содержащий объекты класса Rectangle:
C#
1
List<Rectangle> parts = new List<Rectangle>();
Миниатюры
Разбиение фигуры с тупыми углами на произвольным прямоугольники  
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.04.2017, 08:32
Ответы с готовыми решениями:

Алгоритм разбивки многоугольника с прямыми углами на прямоугольники
Всем привет. Все пытаюсь нагуглить информацию по теме, но кругом одна сплошная триангуляция. Мой задача проще - имеется многоугольник, у...

Исправить код, который рисует фигуры с закругленными углами
Вот есть код кто может его всячески на вид изменить но суть не менять? может даже облегчить его код по сути рисует фигуры в которых...

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

4
0 / 0 / 1
Регистрация: 21.10.2012
Сообщений: 51
27.04.2017, 08:39  [ТС]
Вообще самый простой способ это провести линии по вертикали и горизонтали по всем точкам ГО, на пересечениях создать прямоугольники, но реализовать что то не получается
Миниатюры
Разбиение фигуры с тупыми углами на произвольным прямоугольники  
0
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10425 / 5155 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
27.04.2017, 12:44
Лучший ответ Сообщение было отмечено Ичи как решение

Решение

Цитата Сообщение от Ичи Посмотреть сообщение
алгоритм, для разбиения геометрической фигуры произвольной формы (развернутая гофрокоробка) с углами в 90 градусов на произвольные прямоугольники (не обязательно с одинаковыми сторонами)
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
        private IEnumerable<Rectangle> ExtractRectangles(IEnumerable<Point> points)
        {
            var path = new GraphicsPath();
            path.AddPolygon(points.ToArray());
 
            using (var region = new Region(path))
            using (var gr = Graphics.FromHwnd(IntPtr.Zero))
            while (!region.IsEmpty(gr))
            {
                var bounds = Rectangle.Round(region.GetBounds(gr));
                //ищем начало гориз линии
                var fromX = 0;
                var fromY = bounds.Y;
                for (; fromY <= bounds.Bottom; fromY++)
                for (int x = bounds.X; x <= bounds.Right; x++)
                if (region.IsVisible(new Point(x, fromY)))
                {
                    fromX = x;
                    goto next;
                }
 
                next:
                //ищем конец гориз линии
                var toX = 0;
                for (int x = fromX; x <= bounds.Right; x++)
                {
                    if (region.IsVisible(new Point(x, fromY)))
                        toX = x;
                    else
                        break;
                }
 
                //ищем высоту
                var h = 1;
                for (int y = fromY + 1; y <= bounds.Bottom; y++)
                {
                    if (Enumerable.Range(fromX, toX - fromX + 1).All(x=>region.IsVisible(new Point(x, y))))
                        h++;
                    else
                        break;
                }
 
                //вырезаем прямоугольник
                var rect = new Rectangle(fromX, fromY, toX - fromX + 1, h);
                region.Exclude(rect);
 
                //
                yield return rect;
            }
        }
1
0 / 0 / 1
Регистрация: 21.10.2012
Сообщений: 51
28.04.2017, 22:39  [ТС]
Не смог разобраться в коде, уже очень профессионально написано.
Попытался свой вариант сделать, но как только протестировал с ГО как на закрепленной картинке все поплыло.
Миниатюры
Разбиение фигуры с тупыми углами на произвольным прямоугольники  
0
0 / 0 / 1
Регистрация: 21.10.2012
Сообщений: 51
29.04.2017, 10:36  [ТС]
Все разобрался, работает отлично, спасибо дружище!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.04.2017, 10:36
Помогаю со студенческими работами здесь

Разбиение фигуры линиями
Здравствуйте! Есть следующая задача: Найти все (максимальное количество) фигуры, полученные в ходе разбиения основной фигуры при помощи...

Как считать матрицу из файла с произвольным типом элементов и произвольным размером матрицы
У меня есть шаблонный класс Matrix, шаблоном является тип элементов. Как можно считать матрицу элементов шаблонного типа из файла, если мы...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru