Задать вопрос
@kirillleogky

Как сделать рисование canvas?

Есть код: https://jsfiddle.net/d92pfL5e/1/

При использовании Pencil на canvas иногда срабатывает а иногда нет
И когда не срабатывает пишет ошибку:
5dcef8df5ab59005387931.png
281 строка:
frame4x4[currCanvasColorRow][currCanvasColorColumn] = `${currColor.style.backgroundColor}`;


Я понимаю что код не очень
Подскажите пожалуйста как добавлять по клику пиксель с цветом в блоке "Current color"? И без такой ошибки
  • Вопрос задан
  • 80 просмотров
Подписаться 1 Средний Комментировать
Решения вопроса 1
0xD34F
@0xD34F Куратор тега JavaScript
А-а-а-а-а-а-а-а-а!!!!!!111111

ЧТО ЭТО ТАКОЕ??!
function calcRowAndColumn(coordinates) {
  let currPosition;
  if (coordinates > 0 && coordinates < 4) {
    currPosition = 0;
  }
  if (coordinates > 4 && coordinates < 8) {
    currPosition = 1;
  }
  if (coordinates > 8 && coordinates < 12) {
    currPosition = 2;
  }
  if (coordinates > 12 && coordinates < 16) {
    currPosition = 3;
  }
  if (coordinates > 16 && coordinates < 20) {
    currPosition = 4;
  }
  if (coordinates > 20 && coordinates < 24) {
    currPosition = 5;
  }
  if (coordinates > 24 && coordinates < 28) {
    currPosition = 6;
  }
  if (coordinates > 28 && coordinates < 32) {
    currPosition = 7;
  }
  if (coordinates > 32 && coordinates < 36) {
    currPosition = 8;
  }
  if (coordinates > 36 && coordinates < 40) {
    currPosition = 9;
  }
  if (coordinates > 40 && coordinates < 44) {
    currPosition = 10;
  }
  if (coordinates > 44 && coordinates < 48) {
    currPosition = 11;
  }
  if (coordinates > 48 && coordinates < 52) {
    currPosition = 12;
  }
  if (coordinates > 52 && coordinates < 56) {
    currPosition = 13;
  }
  if (coordinates > 56 && coordinates < 60) {
    currPosition = 14;
  }
  if (coordinates > 60 && coordinates < 64) {
    currPosition = 15;
  }
  if (coordinates > 64 && coordinates < 68) {
    currPosition = 16;
  }
  if (coordinates > 68 && coordinates < 72) {
    currPosition = 17;
  }
  if (coordinates > 72 && coordinates < 76) {
    currPosition = 18;
  }
  if (coordinates > 76 && coordinates < 80) {
    currPosition = 19;
  }
  if (coordinates > 80 && coordinates < 84) {
    currPosition = 20;
  }
  if (coordinates > 84 && coordinates < 88) {
    currPosition = 21;
  }
  if (coordinates > 88 && coordinates < 92) {
    currPosition = 22;
  }
  if (coordinates > 92 && coordinates < 96) {
    currPosition = 23;
  }
  if (coordinates > 96 && coordinates < 100) {
    currPosition = 24;
  }
  if (coordinates > 100 && coordinates < 104) {
    currPosition = 25;
  }
  if (coordinates > 104 && coordinates < 108) {
    currPosition = 26;
  }
  if (coordinates > 108 && coordinates < 112) {
    currPosition = 27;
  }
  if (coordinates > 112 && coordinates < 116) {
    currPosition = 28;
  }
  if (coordinates > 116 && coordinates < 120) {
    currPosition = 29;
  }
  if (coordinates > 120 && coordinates < 124) {
    currPosition = 30;
  }
  if (coordinates > 124 && coordinates < 128) {
    currPosition = 31;
  }
  return currPosition;
}

Во-первых, всё это делается в одну строку (функция selectPixel может быть сокращена точно так же):

const calcRowAndColumn = coord => Math.floor(coord / 4);

Во-вторых, возьмём, например, следующий кусок:

if (coordinates > 112 && coordinates < 116) {
  currPosition = 28;
}
if (coordinates > 116 && coordinates < 120) {
  currPosition = 29;
}

Пусть coordinates равен 116. Чему тогда будет равен currPosition? А ничему, undefined - строгие неравенства, больше-меньше, 116 никак не обрабатывается. И остальные граничные значения, кратные четырём, тоже. Это, если что, причина получаемых вами ошибок - эти undefined вы пытаетесь использовать как индексы многомерного массива.
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 1
TTATPuOT
@TTATPuOT
https://code.patriotovsky.ru/
Скрипт "Не может прочитать значение 7 у undefined".
Из того, что вы привели - undefined это или
frame4x4[currCanvasColorRow]
или
frame4x4
Скорее первое. Сделайте так, чтобы frame4x4[currCanvasColorRow] небыл undefined и всё заработает.

А вообще, неприлично такие вопросы задавать, в тексте ошибки всё четко написано.
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
15 дек. 2024, в 01:57
120000 руб./за проект
15 дек. 2024, в 01:44
400 руб./за проект
15 дек. 2024, в 01:17
100000 руб./за проект