--- title: Добавление функций в нашу демонстрацию отбойных шаров slug: Learn/JavaScript/Objects/Adding_bouncing_balls_features translation_of: Learn/JavaScript/Objects/Adding_bouncing_balls_features original_slug: Learn/JavaScript/Объекты/Adding_bouncing_balls_features ---
В этом упражнении мы будем использовать проект прыгающих шаров из предыдущей статьи и добавим в него новые интересные возможности.
Требования: | Перед тем как приступить к этому упражнению нужно выполнить задания из всех статей текущего модуля. |
---|---|
Цель: | Проверить насколько хорошо вы понимаете объекты и связанные с ними конструкции в языке Javascript. |
Для начала скопируйте файлы index-finished.html, style.css и main-finished.js из предыдущей статьи в новую директорию на вашем компьютере.
Для выполнения упражнения вы можете использовать сайт JSBin или Thimble. Вы можете вставлять HTML, CSS и JavaScript код в один из этих онлайн-редакторов. Если ваш онлайн-редактор не поддерживает раздельные панели для редактирования JavaScript/CSS кода, то вы можете встроить код в HTML с помощью тегов <script>
/<style>
.
Примечание. Если у вас что-то не получается — попросите о помощи. Более подробная информация находится в секции {{anch("Assessment or further help")}} в конце этой страницы.
Наша весёлая демонстрация шаров - это весело, но теперь мы хотим сделать её немного более интерактивной, добавив контролируемый пользователем злой круг, который будет есть шары, если он их поймает. Мы также хотим проверить ваши навыки создания объектов, создав общий объект Shape()
, который могут наследовать наши шары и злой круг. Наконец, мы хотим добавить счётчик очков, чтобы отслеживать количество оставшихся шаров для захвата.
Следующий скриншот даёт вам представление о том, как должна выглядеть готовая программа:
Чтобы дать вам больше идеи, посмотрите на законченный пример (не заглядывая в исходный код!)
В следующих разделах описывается, что вам нужно делать.
Прежде всего, измените существующий конструктор Ball()
так, чтобы он стал конструктором Shape()
и добавил новый конструктор Ball()
:
Shape()
должен определять свойства x
, y
, velX
и velY
, так же, как и конструктор Ball()
, но не свойства color
и size
.exists
, которое используется для отслеживания наличия шаров в программе (не было съедено злым кругом). Это должно быть логическое (true
/ false
).Ball()
должен наследовать свойства x
, y
, velX
, velY
и exists
из конструктора Shape()
.color
и size
, как это сделал оригинальный конструктор Ball()
.prototype
и constructor
конструктора Ball()
соответствующим образом.Определения меток шара draw()
, update()
и collisionDetect()
должны быть такими же, как и раньше.
Вам также нужно добавить новый параметр в новый вызов конструктора new Ball() ( ... )
- параметр exists
должен быть 5-м параметром и ему должно быть присвоено значение true
.
На этом этапе попробуйте перезагрузить код - он должен работать так же, как и раньше, с нашими перепроектированными объектами.
Теперь пришло время встретить плохого парня - EvilCircle()
! Наша игра будет включать только один злой круг, но мы все ещё будем определять его с помощью конструктора, который наследует от Shape()
, чтобы дать вам некоторую практику. Возможно, вам захочется добавить ещё один круг в приложение, которое может контролироваться другим игроком или иметь несколько злобных окружений, управляемых компьютером. Вы, вероятно, не собираетесь захватить мир одним злым кругом, но он будет делать для этой оценки.
Конструктор EvilCircle()
должен наследовать x
, y
, velX
, velY
и exists
из Shape()
, но velX
и velY
должны всегда равняться 20.
Вы должны сделать что-то вроде Shape.call(this, x, y, 20, 20, exists);
Он также должен определить свои собственные свойства следующим образом:
color
— 'white'
size
— 10
Опять же, не забудьте определить свои унаследованные свойства как параметры в конструкторе и правильно установить свойства prototype
и constructor
.
EvilCircle()
должен иметь четыре метода, как описано ниже.
draw()
Этот метод имеет ту же цель, что и метод draw()
метода Ball()
: он рисует экземпляр объекта на холсте. Он будет работать очень схожим образом, поэтому вы можете начать с копирования определения Ball.prototype.draw
. Затем вы должны внести следующие изменения:
fillStyle
и fill()
до strokeStyle
и sstroke()
.lineWidth
где-нибудь после вызова beginPath()
(3 будем делать).checkBounds()
Этот метод будет делать то же самое, что и первая часть функции Ball()
's update()
, чтобы посмотреть, не исчезнет ли злой круг от края экрана и не прекратит это делать. Опять же, вы можете просто скопировать определение Ball.prototype.update
, но есть несколько изменений, которые вы должны сделать:
if()
, если тесты возвращают true, мы не хотим обновлять velX
/ velY
; мы хотим вместо этого изменить значение x
/ y
, так что злой круг возвращается на экран немного. Добавление или вычитание (по мере необходимости) свойства size
злого круга имеет смысл.setControls()
Этот метод добавит обработчик событий onkeydown
к объекту window
, чтобы при нажатии определённых клавиш клавиатуры мы могли перемещать злой круг вокруг. Следующий код должен быть помещён внутри определения метода:
var _this = this; window.onkeydown = function(e) { if (e.keyCode === 65) { _this.x -= _this.velX; } else if (e.keyCode === 68) { _this.x += _this.velX; } else if (e.keyCode === 87) { _this.y -= _this.velY; } else if (e.keyCode === 83) { _this.y += _this.velY; } }
Поэтому, когда нажата клавиша, проконсультируется о свойствах keyCode объекта события, чтобы увидеть, какая клавиша нажата. Если это один из четырёх, представленных указанными ключевыми кодами, тогда злой круг будет перемещаться влево / вправо / вверх / вниз.
var _this = this
; в позиции, в которой он находится? Это как-то связано с функциональной областью.collisionDetect()
Этот метод будет действовать очень похоже на метод collisionDetect()
в Ball()
, поэтому вы можете использовать его в качестве основы для этого нового метода. Но есть несколько отличий:
if
вам больше не нужно проверять, совпадает ли текущий мяч на итерации с шаром, который выполняет проверку, потому что он больше не является мячиком, это злой круг! Вместо этого вам нужно выполнить проверку, чтобы проверить, существует ли проверенный шар (с каким свойством вы могли бы это сделать?). Если этого не существует, он уже был съеден злым кругом, поэтому нет необходимости проверять его снова.if
-выражении вы больше не хотите, чтобы объекты меняли цвет при обнаружении столкновения - вместо этого вы хотите установить любые шары, которые сталкиваются с злым кругом, чтобы больше не существовать (опять же, как вы думаете, d сделать это?).Теперь мы определили злой круг, нам нужно на самом деле заставить его появиться на нашей сцене. Для этого вам нужно внести некоторые изменения в функцию loop()
.
setControls()
. Вам нужно только сделать эти две вещи один раз, а не на каждой итерации цикла.draw()
, update()
и collisionDetect()
для каждого из них, делайте так, чтобы эти функции вызывались только в том случае, если текущий шар существует.draw()
, checkBounds()
и collisionDetect()
для злого шарика.Чтобы выполнить счётчик счётчиков, выполните следующие действия:
p { position: absolute; margin: 0; top: 35px; right: 5px; color: #aaa; }
Если вы проводите эту оценку в рамках организованного курса, вы должны уметь отдать свою работу своему учителю / наставнику для маркировки. Если вы самообучаетесь, то вы можете получить руководство по маркировке довольно легко, задав тему обсуждения для этого упражнения или в IRC-канале #mdn в Mozilla IRC. Сначала попробуйте упражнение - ничего не выиграть от обмана!
{{PreviousMenuNext("Learn/JavaScript/Objects/Object_building_practice", "", "Learn/JavaScript/Objects")}}