< Return to Video

Модифікація масивів (Відео версія)

  • 0:01 - 0:05
    До цих пір ми бачили, як створити масив
    і отримати доступ до нього.
  • 0:05 - 0:09
    Так, як й інші змінні, проте, одина дійсно
    цікава можливість масивів це те, що ми
  • 0:09 - 0:13
    можемо змінювати їх динамічно
    під час виконання програми.
  • 0:13 - 0:16
    Гаразд, дозвольте мені показати вам, що
    я маю на увазі під цим.
  • 0:16 - 0:20
    Отже, у нас є ця програма, що відображає
    Хопера, що тримає пару повітряних куль;
  • 0:20 - 0:21
    надзвичайно милий.
  • 0:21 - 0:28
    І це працює так як у нас є цей xPositions
    масив, що містить два числа, які говорять
  • 0:28 - 0:30
    де ми хочемо мати ці повітряні кулі.
  • 0:30 - 0:35
    І потім тут у нас є цей цикл, що проходить
    через кожний елемент в цьому масиві.
  • 0:35 - 0:42
    І для кожного з них, він малює лінію від
    "х"вниз до руки Хопера, а потім малює
  • 0:42 - 0:47
    еліпс на "х" що є 30х40 пікселів, і це
    наша повітряна куля.
  • 0:48 - 0:52
    Класно. І тепер ми бачимо, як це працює
    ми знаємо, що якщо ми хочемо показати
  • 0:52 - 0:57
    ще одину повітряну кулю, що ми можемо
    просто додати номер в масиві, чи не так?
  • 0:57 - 0:58
    наприклад 300.
  • 0:58 - 1:02
    Гарно. Тепер у нас є три повітряних кулі
    для щасливого Хопера.
  • 1:03 - 1:09
    Але, припустимо, ми хочемо дати можливість
    користувачеві, який не знає, як кодувати,
  • 1:09 - 1:11
    додавати нові повітряні кулі.
  • 1:11 - 1:15
    Таким чином, ми хотіли б дати програму
    користувачеві і сказати: "Ви можете
  • 1:15 - 1:18
    натиснути кнопку, де б ви хотіли повітряну
    кулю, і вона буде відображатися."
  • 1:18 - 1:21
    Чи не буде це круто? Я гадаю, що так.
  • 1:21 - 1:25
    І як ми повинні це робити? отже, ми
    хочемо, щоб наша програма змінювалась
  • 1:25 - 1:27
    з плином часу, чи не так?
  • 1:27 - 1:30
    Кожен раз, коли користувач натисне,
    повітряна куля з'явиться там.
  • 1:30 - 1:37
    Отже, почнемо, перемістиши все у функцію
    "draw" і це легко змінювати з часу.
  • 1:37 - 1:43
    Тому, ми просто перемістимо це вниз сюди
    і відступимо тут. Чудово.
  • 1:43 - 1:48
    І тепер ми хочемо, перевіряти чи
    користувач натискає мишею прямо зараз?
  • 1:48 - 1:55
    Ми можемо зробити це з нашим "if".
    If(mousePressed), а тоді що будемо робити.
  • 1:55 - 2:00
    Так що ж ми будемо робити? Якщо натиснути
    мишею, то ми хочемо, якось додати число
  • 2:00 - 2:01
    до цього масиву.
  • 2:01 - 2:04
    І давайте ще раз зробимо лише ці
    два елементи. Добре.
  • 2:04 - 2:09
    Отже, хочемо, додати число до цього масиву
    якось. І я покажу вам один спосіб, яким ви
  • 2:09 - 2:11
    могли б зробити це.
  • 2:11 - 2:18
    Таким чином, ми можемо
    ввести xPositions [2] = mouseX;
  • 2:18 - 2:21
    Добре, і дозвольте мені показати вам,
    як це працює.
  • 2:22 - 2:27
    Я натиснула, і я отримала повітряну кулю.
    Отже як це зроили?
  • 2:27 - 2:34
    Це говорить, що xPositions [2] каже знайти
    цей масив, і знайти елемент на 2 місці,
  • 2:34 - 2:38
    і пам'ятайте, що це третій елемент, тому
    що наші масиви починаються з нуля.
  • 2:38 - 2:42
    І якщо поглянете, то немає елемента 3,
    чи не так? Там немає нічого в цьому місці.
  • 2:42 - 2:46
    І він каже, знайти це, а потім внести
    в нього mouseX
  • 2:46 - 2:51
    А так як там нічого немає, значення
    переходить від нічого до mouseX.
  • 2:51 - 2:56
    І тепер наш масив має довжину в 3 елементи
    і цей цикл for знизу тут, що проходить через
  • 2:56 - 3:00
    нього, завершить малювати
    третю повітряну кулю.
  • 3:01 - 3:04
    І це дуже класно, дозвольте мені натиснути
    ще трохи, щоб показати вам, як це працює.
  • 3:04 - 3:09
    Так що ви бачите кожен раз, коли натискаю,
    він продовжує малювати третю повітряну
  • 3:09 - 3:11
    де б я не натиснула мишею.
  • 3:11 - 3:19
    І це тому, що ми постійно переписуємо
    розташування 2 - те що з індексом 2.
  • 3:19 - 3:23
    Ми постійно оновлюємо,
    поточну mouseX.
  • 3:23 - 3:30
    Отже, ми матимемо тільки 3 повітряні кулі,
    тому що одина в позиції 0, ця у 1, і ми
  • 3:30 - 3:34
    постійно змінюємо позицію 2. Зрозуміло?
  • 3:34 - 3:39
    І це круто але те, що ми дійсно хочемо, це
    щоб користувач міг зробити купу повітряних
  • 3:39 - 3:40
    куль, чи не так?
  • 3:40 - 3:43
    Таким чином, кожен раз, коли користувач
    натисне, з'явиться нова куля.
  • 3:43 - 3:50
    Це означає, що ми повинні постійно
    збільшувати індекс елементу масиву,
  • 3:50 - 3:51
    який ми зберігаємо його всередині.
  • 3:51 - 3:56
    Ми не хочемо, щоб їх було 2 кожен раз,
    а щоб було 2, а потім 3, 4, 5, 6 і т.д.
  • 3:56 - 4:01
    І ми могли б зробити це, маючи невелику
    змінну лічильника. Тож введемо newind = 2;
  • 4:01 - 4:05
    Це те, з чого вона буде початинатись,
    а потім ми введемо newind замість 2.
  • 4:06 - 4:09
    І тоді те, що ми дійсно хочемо зробити,
    це ввести newind ++
  • 4:09 - 4:15
    Отже, кожен раз додаючи 1 до цього. ми
    почнемо як 2, а потім стане 3, а тоді 4.
  • 4:15 - 4:18
    Так що кожен раз, натискаючи, вона
    зростатиме. Так давайте спробуємо це.
  • 4:19 - 4:22
    Безліч повітряних куль.
    Вечірка повітряних куль
  • 4:22 - 4:29
    Це чудово, чи не так? Але це не найкращий
    спосіб зробити це, так як це складається з
  • 4:29 - 4:32
    додавання елементів в масив, те що ми
    хочемо робити багато.
  • 4:32 - 4:35
    Таким чином, у нас є набагато простіший
    спосіб зробити це.
  • 4:35 - 4:39
    Отже, дозвольте мені просто видалити це
    все, що ми зробили. Гаразд, отже, нам не
  • 4:39 - 4:42
    потрібно це, і більше не буде потрібно.
    Ми просто прокоментуємо це.
  • 4:42 - 4:50
    Отже, те як ми робимо це, ми вводимо
    xPositions.push, а потім mouseX.
  • 4:51 - 4:56
    Так що, те ми робимо тут ми називаємо
    методом масив з xPositions.
  • 4:56 - 5:01
    Так ми викликаємо команду по масиву.
    Ми говоримо масиву, "Ей, перемісти це нове
  • 5:01 - 5:05
    значення, mouseX, перемісти його на кінець
    вашого масиву."
  • 5:05 - 5:09
    Отже, кожен раз коли це викликається,
    тобто натискають мишею, вона буде
  • 5:09 - 5:12
    дивитися на mouseX і сунути його до кінця масиву.
  • 5:12 - 5:16
    Отже, масив повинен ставати більшим
    більшим і більшим. Так що давайте
  • 5:16 - 5:17
    перезапустимо і спробуємо це.
  • 5:18 - 5:22
    Це спрацювало! І це набагато менше коду,
    ніж у нас було раніше. Гаразд?
  • 5:23 - 5:26
    І зазвичай, ви будете хотіти використати
    "push" якщо ви збираєтеся додати
  • 5:26 - 5:28
    щось в масив, як це.
  • 5:28 - 5:30
    І це дуже акуратно так як ви можете просто
    мати ці масиви, що стають все більшими
  • 5:30 - 5:32
    і більшими і більшими під час програми.
  • 5:32 - 5:34
    Як і коли у вас є анімація або коли у вас
    є те що використовує користувач і потім
  • 5:34 - 5:36
    ви можете зробити набагато більше.
  • 5:36 - 5:40
    Так що тепер ви вже бачили 90% того,
    для чого ви, ймовірно, використовуватимете
  • 5:40 - 5:42
    масиви і шляхи їхнього використання.
  • 5:42 - 5:45
    Але є ще багато чого, що ви можете робити
    з масивами. Так що якщо у вас є питання,
  • 5:45 - 5:47
    просто запитуйте їх в обговоренні.
  • 5:47 - 5:50
    Але в першу чергу переконайтеся, чи
    освоїоли ці основи.
Title:
Модифікація масивів (Відео версія)
Description:

Це відео показує, як динамічно змінювати вміст масиву в той час як програма працює.

more » « less
Video Language:
English
Duration:
05:51
Іван Соломаха edited Ukrainian subtitles for Modifying Arrays (Video Version)
Іван Соломаха edited Ukrainian subtitles for Modifying Arrays (Video Version)
Іван Соломаха edited Ukrainian subtitles for Modifying Arrays (Video Version)
Іван Соломаха edited Ukrainian subtitles for Modifying Arrays (Video Version)
Іван Соломаха edited Ukrainian subtitles for Modifying Arrays (Video Version)
Іван Соломаха edited Ukrainian subtitles for Modifying Arrays (Video Version)
Іван Соломаха edited Ukrainian subtitles for Modifying Arrays (Video Version)
Іван Соломаха edited Ukrainian subtitles for Modifying Arrays (Video Version)
Show all

Ukrainian subtitles

Incomplete

Revisions