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

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

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

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




Оцени работу

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

24. Оля
Оля
ответить
→  Anton Sozykin  # Теория ООП / Интерфейс. VIP. Пересечение прямоугольников. / 2015-12-15 16:41

Антон, отлично уже все у тебя получилось, рада что ты подошел к финалу! Жду с нетерпением твоего следующего отчета! :)


  • Отчёт оценивали:
    8005Александр+1   459Сергей Сергеевич+1   1Евгений Волосатов+1   5705Андрей +1   4992Николай+1   7645Александр Львович+1   6458Илья+1   7901Влад+1   8Василевская Елена0   3747Сергей+1   6925Артём+1   6203Николай (nick27m)+1   7276Ильшат+1   6958Кирилл+1   4395Денис+1   8274Виктор 0   7448Sergey Shumskiy+1   5882Александр Широков+1   7449Elena Karpanova+1   7980Сергей Лузум+1   24Оля+1   4732Sergey+1  

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




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

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

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

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