Курсы по программированию

Формула программиста
основатель — Волосатов Евгений Витольдович
Вступай в Телеграм чат проекта

Теория ООП / Интерфейс. VIP. Пересечение прямоугольников.

  • На этом уроке мы допишем метод Box.Поймал()
    и запустим игру с квадратиками.
    Потом попробуем подружить квадратики с кружками,
    увидим, что это не так просто, да собственно и не нужно.
    Но возможно.
  • Дата отправки отчёта: 27 июня 2016 г.
  • Задание выполнено: за 23 мин.
  • Чему научился: Научился делать методы проверки для боксиков и одновременно выводить кружки и боксики.
  • Что было сложным: Ничего.
  • Комментарии: Интерфейсы это мощь. Позволяют малыми усилиями быстро дописывать новый функционал.
  • Оценка видео-уроку:
Отчёт от 7119 за Теория ООП / Интерфейс. VIP. Пересечение прямоугольников.




Оцени работу

 
Сохранить страницу:


Начинаем практику по языку C#




Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

После заполнения формы ты будешь подписан на рассылку «C# Вебинары и Видеоуроки», у тебя появится доступ к видеоурокам и консольным задачам.

Несколько раз в неделю тебе будут приходить письма — приглашения на вебинары, информация об акциях и скидках, полезная информация по C#.

Ты в любой момент сможешь отписаться от рассылки.


Научился: Новый способ выявления пересекаемых прямоугольников
Трудности: не было сложностей
нет замечаний


Научился: Условие пересечения прямоугольников.
Трудности: Сложностей не было.
Поначалу решил, что предложенная в уроке функция проверки пересечения двух прямоугольников рассматривает только один частный случай, слишком уж "простая" она на вид. Однако проверил на практике - работает. Здесь я предположил, что боксики двигаются слишком быстро, поэтому в какой-то момент срабатывает "то самое" частное условие и боксик голится. Я не верил, что это решение корректное. Для полной проверки нужно было замедлять боксики и проверять на глаз пересечения, но мне не хотелось этим заниматься. Я уже хотел было отправить отчет, но тут вспомнил совет Евгения Витольдовича, что следует довести дело до конца. Тут осенило, думаю, дай-ка создам unit-тесты на функцию isIntersect и проверю все возможные варианты пересечений и не пересечений. В итоге, нарисовал на бумаге разные варианты расположения прямоугольников, получалась 31 комбинация, создал для каждой из них свой тест, каждый тест запускал по мере написания и меня каждый раз шокировало, что функция-то работает:D На втором скриншоте показаны результаты выполнения 31 теста, все проходят. Подумал, может в Qt какая-нибудь бага, регрессировал код тестируемой функции, добавил в нее ошибку и тесты посыпались как надо, чудо. В общем, функция Евгения Витольдовича работает как надо. Позже я еще раз логически проанализировал функцию проверки и да, тут уже понял, что код корректен. Первое впечатление оказалось обманчивым, следует внимательно читать код. Хороший урок для меня.