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

Формула программиста
основатель — Волосатов Евгений Витольдович
Приходи на 3-дневный мастер-класс по C#

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

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




Оцени работу

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

24. Олюшка
Олюшка
ответить
→  Frank  # Теория ООП / Интерфейс. VIP. Пересечение прямоугольников. / 2016-02-21 22:24

Франк, я очень рада что у тебя все отлично! :)


  • Отчёт оценивали:
    5565Frank+1   7645Александр Львович+1   1Евгений Волосатов+1   8886Михаил Ермишин+1   6391Владимир+1   9427Иван Алексеевич0   459Сергей Сергеевич+1   5760Мариша +1   6925Артём+1   689Igorenzia+1   2146Иван+1   6644valerys Nikola+1   4992Николай+1   2639Морозов Юрий Александрович+1   6195sergey+1   4060Игорь+1   4467Alcatraz+1   791Валерий Жданов+1   24Олюшка+1   7157muxasio+1   5369Archi+1  

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




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

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

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

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