Форум программистов, компьютерный форум, киберфорум
JavaScript: HTML5 Canvas
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/6: Рейтинг темы: голосов - 6, средняя оценка - 4.83
3 / 3 / 0
Регистрация: 08.06.2013
Сообщений: 212

Пишу игру-арканоид на канвасе js. Когда мячик сбил все кирпичи, надо вывести сообщение "YOU WON!'

12.05.2023, 16:32. Показов 1353. Ответов 6

Студворк — интернет-сервис помощи студентам
Алерт срабатывает раньше времени, когда bricks.length = 1. Но если заключить его в setTimeout, всё работает корректно. Почему так происходит? Заранее спасибо
JavaScript
1
2
3
4
5
6
7
8
if (! bricks.length) {
                context.fillStyle = 'blue'
                context.fillRect(0, 0, CANVAS_WIDTH, CANVAS_HEIGHT)
                window.setTimeout(() => {
                    alert('YOU WON!!!')
                    window.location.reload()
                })
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.05.2023, 16:32
Ответы с готовыми решениями:

Арканоид,кирпичи разных уровней
Привет, делаю арканоид, пытаюсь сделать кирпичи 2-го уровня т.е кирпич должен уничтожаться только в 2 попадания шариком. Есть мысль: после...

надо решить задачу: a*b=x,надо вывести х, а когда a и b равны 0, то написать что корней множество, а когда a или b равен 0, то вывести что корней нет
Здравствуйте господа... У меня вот такая проблема, на завтра надо решить задачу: a*b=x,надо вывести х, а когда a и b равны 0, то написать...

Игра-арканоид в канвасе на React. Почему скорость мяча меняется в зависимости от состояния платформы?
Если платформа неподвижна, мячик двигается медленно (со скоростью, меньшей скорости платформы). Если платформа двигается, скорость мяча...

6
Эксперт JSЭксперт HTML/CSS
 Аватар для krvsa
3806 / 1643 / 428
Регистрация: 14.03.2022
Сообщений: 4,090
12.05.2023, 17:03
Цитата Сообщение от хгаля Посмотреть сообщение
Алерт срабатывает раньше времени, когда bricks.length = 1
А как же твое условие?
Цитата Сообщение от хгаля Посмотреть сообщение
JavaScript
1
if (! bricks.length)
Оно не сработает при
JavaScript
1
bricks.length = 1
1
3 / 3 / 0
Регистрация: 08.06.2013
Сообщений: 212
22.05.2023, 09:56  [ТС]
Вот именно. Но почему-т срабатывает
0
Эксперт JSЭксперт HTML/CSS
 Аватар для krvsa
3806 / 1643 / 428
Регистрация: 14.03.2022
Сообщений: 4,090
22.05.2023, 10:50
Цитата Сообщение от хгаля Посмотреть сообщение
Но почему-т срабатывает
Значит на момент проверки условия bricks.length != 0...
Кто такой этот bricks?

Предположу (это ведь ветка про Реакт) что это некий стейт... Чуть выше ты его обновил и сразу проверяешь на его длину...
Но не учитываешь что обновление стейта асинхронное действо и собственно обновление произойдет "не сейчас", а "потом".
1
Модератор
Эксперт JS
 Аватар для Eva Rosalene
5241 / 2115 / 416
Регистрация: 06.01.2013
Сообщений: 4,846
23.05.2023, 04:43
Цитата Сообщение от хгаля Посмотреть сообщение
Алерт срабатывает раньше времени, когда bricks.length = 1
А как вы это понимаете? По рисунку на канвасе? Он не обновляется, например, по дефолту, в Chrome 113 до завершения текущего контекста выполнения, который блокируется alert.

Демо такого поведения: https://codepen.io/eva-rosalene/pen/XWxoQod

Добавлено через 39 секунд
Причина этого, кажется, в атрибуте desynchronized, но я не уверена, и поменять это поведение мне не удалось.
1
3 / 3 / 0
Регистрация: 08.06.2013
Сообщений: 212
24.05.2023, 13:08  [ТС]
Мне тоже не удалось.
0
9037 / 2937 / 494
Регистрация: 05.10.2013
Сообщений: 7,962
Записей в блоге: 216
27.05.2023, 12:22
На сайте с документацией (MDN Web Docs) есть пошаговая инструкция по Арканойд с переводом на русский: 2D игра на чистом JavaScript. В ней есть раздел Отображение сообщения о победе, когда все кирпичи были уничтожены

JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
function collisionDetection() {
    for(var c=0; c<brickColumnCount; c++) {
        for(var r=0; r<brickRowCount; r++) {
            var b = bricks[c][r];
            if(b.status == 1) {
                if(x > b.x && x < b.x+brickWidth && y > b.y && y < b.y+brickHeight) {
                    dy = -dy;
                    b.status = 0;
                    score++;
                    if(score == brickRowCount*brickColumnCount) {
                        alert("YOU WIN, CONGRATULATIONS!");
                        document.location.reload();
                    }
                }
            }
        }
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.05.2023, 12:22
Помогаю со студенческими работами здесь

Когда запускаю игру в юнити все хорошо а когда портировал на андроид и нажимаю на кнопки запускается игра!
Когда запускаю игру в юнити все хорошо а когда портировал на андроид и нажимаю на кнопки запускается игра!!!!!!!!! В юнити все хорошо...

не пойму причину загрузки цп на 98%, когда просто сижу за копьютером всё норм,стоит мне запустить игру,так всё
Уже 2 месяца не пойму причину загрузки цп на 98%, когда просто сижу за копьютером всё норм,стоит мне запустить игру,так всё жесть...

Создать игру арканоид на C# с спрайтами
Очень нужна помощь не могу разобраться как создать классы для игры арканоид. Как через классы загрузить картинки и заставить их...

Как добавить функцию выигрыша в игру Арканоид?
from tkinter import * import time import random class Ball: def __init__(self, canvas, color, paddle, bricks, score): ...

Пишу программу которая меняет в тексте ( Panel) цвет,шрифт,размер написал все как надо выдает ошибку
Как исправить эту ошибку нужно ввести что то в var? Incompatible types Tcolor and strings Incompatible types integer and strings ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru