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

Класс с использованием canvas

30.08.2019, 13:25. Показов 989. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
function getRandom(min, max)
{
    return Math.floor(min + Math.random() * (max + 1 - min));
}
 
 
var canvas = document.getElementById("canvas");
var ctx = canvas.getContext("2d");
 
canvas.width = window.innerWidth - 25;
canvas.height = window. innerHeight - 25;
 
 
class Star
{
    constructor()
    {
        this.x = getRandom(25, window.innerWidth - 25);
        this.y = getRandom(25, window.innerHeight - 25);
 
        ctx.beginPath();
        ctx.fillStyle = "#fff";
        ctx.arc(this.x, this.y, 3, 0, 2 * Math.PI, true);
        ctx.fill();
 
        this.starMove();
    }
 
    starMove()
    {
        console.log(this.x);
        ctx.clearRect(this.x - 3 - 1, this.y - 3 - 1, 3 * 2 + 2, 3 * 2 + 2);
        ctx.fillStyle = "#fff";
        ctx.arc(this.x, this.y, 3, 0, 2 * Math.PI, true);
 
        if(this.y > window.innerHeight / 2)
        {
            this.y++;
        }
        else
        {
            this.y--;
        }
 
        if(this.x > window.innerWidth / 2)
        {
            this.x++;
        }
        else
        {
            this.x--;
        }
 
        window.requestAnimationFrame(this.starMove);
    }
}
 
var starCount = 5;
 
for(var i = 0; i < starCount; i++)
{
    new Star();
}
На 31 строке в консоль выводится ошибка: Cannot read property 'x' of undefined. Но всё равно console.log работает, т.е. this.x выводит.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.08.2019, 13:25
Ответы с готовыми решениями:

Canvas html5, как разместить черный пискель в центре canvas'a?
как разместить черный пискель в центре canvas'a?

Часы с использованием Canvas
В-общем есть программа, аналоговые часы, с будильником. Проблемы такие: 1. Часы идут в обратную сторону 2. Часы отражены по горизонтали...

Трансформация изображения с использованием Canvas
Итак, задача: Организовать с помощью мыши перетаскивание опорных точек области Image2 с последующим перерисовыванием трансформированного...

2
1741 / 913 / 480
Регистрация: 05.12.2013
Сообщений: 3,074
30.08.2019, 17:38
Надо в стрелочной функции передавать

JavaScript
1
window.requestAnimationFrame(() => this.starMove);
0
1786 / 1036 / 445
Регистрация: 12.05.2016
Сообщений: 2,550
30.08.2019, 17:50
Цитата Сообщение от ТабуретY Посмотреть сообщение
JavaScript
1
window.requestAnimationFrame(() => this.starMove)
;
ТабуретY, а какая разница? Все равно же так контекст потеряется, или я чего-то не понимаю?

Добавлено через 6 минут
ТабуретY, вот это я подвис с Вашего поста
Kolbasnik,
JavaScript
1
2
3
window.requestAnimationFrame(this.starMove.bind(this));
// or
window.requestAnimationFrame(()=>this.starMove());
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.08.2019, 17:50
Помогаю со студенческими работами здесь

Масштабирование графики на Canvas с использованием TrackBar
На форме с помощью Canvas нарисована прямая. Подскажите, как используя компонент TrackBar менять масштаб этой прямой.

Унаследовать класс от Canvas
Возможно ли создать свой класс, наследующий HTMLCanvasElement? Чтобы с объектом этого класса можно было обращаться и как с эквивалентом...

Класс: Написать класс с использованием объекта класса Integer с обработкой исключения.
Написать класс с использованием объекта класса Integer с обработкой исключения (блок try-catch)

Как передвинуть Rectangle из одной точки в другую на Canvas с использованием timer
Доброго времени суток! Ребят, подскажите как передвинуть Rectangle из одной точки в другую на Canvas с использованием timer, а то я только...

Как создать новый класс используя Canvas?
Мне нужен класс типа list, только с другим интерфейсом. Я хочу, чтоб элементы списка при выделении не светились в синем фоне, а просто...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru