Форум программистов, компьютерный форум, киберфорум
JavaScript для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
4 / 4 / 0
Регистрация: 04.11.2020
Сообщений: 41

Событие Зажатой ЛКМ

19.03.2021, 22:11. Показов 1091. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрые вечер всем. Нужна помощь. Не пойму, что не так с кодом, Приложение пианино. Нужно, что бы при зажатой кнопкой ЛКМ, играли разные ноты, но что то у меня не так, по одиночке работает, но с зажатой нет только первая кнопка и когда дальше двигаешь, то ничего не происходит.
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
const piano = document.querySelector(".piano");
const collectionPiano = document.querySelectorAll(".piano-key");
 
 
function setActiveKey(event) { //active status keys mouse event
  event.target.classList.add("piano-key-active", "piano-key-active-pseudo");
}
 
function removeActiveKey(event) { //remove active status keys mouse event 
  event.target.classList.remove("piano-key-active", "piano-key-active-pseudo");
}
 
function playAudio (data) { //start function playAudio
  const audio = document.querySelector(`audio[data-note="${data}"]`);
  audio.currentTime = 0;
  audio.play();
}
 
function startKeyActive (event) { //mouseover and mouseout events for active status keys, pseudo and play audio
  if (event.target.classList.contains("piano-key")) {
    event.target.classList.add("piano-key-active", "piano-key-active-pseudo");
    const song = event.target.dataset.note;
    playAudio(song);
  }
  collectionPiano.forEach((el) => {
    el.addEventListener("mouseover", playAudio);
    el.addEventListener("mouseover", setActiveKey);
    el.addEventListener("mouseout", removeActiveKey);
  });
};
 
function stopKeyIActive () { //remove mouseover and mouseout events for active status keys, pseudo and play audio
  collectionPiano.forEach((el) => {
    el.classList.remove("piano-key-active", "piano-key-active-pseudo");
    el.removeEventListener("mouseover", playAudio);
    el.removeEventListener("mouseover", setActiveKey);
    el.removeEventListener("mouseout", removeActiveKey);
  });
};
 
piano.addEventListener("mousedown", startKeyActive, playAudio);
document.addEventListener("mouseup", stopKeyIActive);
 
 
window.addEventListener("keydown", (event) => { // Event keyboard - play audio
  if (event.repeat) {
    return;
  } 
  const audioKeys = document.querySelector(`audio[data-key="${event.keyCode}"]`);
  const pianoKey = document.querySelector(`.piano-key[data-key="${event.keyCode}"]`);
  audioKeys.currentTime = 0;
  audioKeys.play(); 
  pianoKey.classList.add('piano-key-active');
 
  window.addEventListener("keyup", () => {
    pianoKey.classList.remove('piano-key-active');
  })
});
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.03.2021, 22:11
Ответы с готовыми решениями:

Событие зажатой клавиши
Можно ли как-то проверять зажата ли клавиша shift, alt?? событие keypress не обрабатывает эти клавиши. И если зажата, то выполнять какую-то...

Перемещение Timage зажатой ЛКМ
Нужно пермещать TImage с помошью зажатой ЛКМ, на подобии Drag&Drop. Но так, чтобы во время перетаскивания обьект отбражался (мб...

В оконном приложении необходимо при зажатой ЛКМ двигать круг по окну
Здравствуйте! В оконном приложении необходимо при зажатой ЛКМ двигать круг по окну. Обработчик писал как-то так: .ELSEIF...

3
123 / 98 / 15
Регистрация: 02.02.2014
Сообщений: 346
20.03.2021, 02:09
http://jsfiddle.net/p9t15uLo/1/
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
class Piano {
   state = {
     is_played: false,
     currentNote : false
   };
   piano  = document.querySelector(".piano_box");
   logBox = document.querySelector(".piano_log");
   
   constructor(name) {
    this.init();
  }
  
  log(msg) {
    //console.log(msg);
    this.logBox.innerHTML = msg + '<br>' + this.logBox.innerHTML;
  
  };
  
   startKeyActive (event) { //mouseover and mouseout events for active status keys, pseudo and play audio  
   let currentNote = event.target.dataset.note;
   if (app.state.is_played == false) {
       app.log("Пианино включено");
    } 
    if (currentNote == app.state.currentNote) {
       return;
    }
    
    app.state.currentNote = currentNote;
    app.state.is_played = true;
    
    app.log("Звучит нота " + app.state.currentNote);
  };
  
  moveKeyActive(event) {
    if (app.state.is_played) {
       app.startKeyActive.call(this, event);
    }
    
  }
  
  stopKeyActive () { //mouseover and mouseout events for active status keys, pseudo and play audio
    app.state.currentNote = false;
    app.state.is_played = false;
    
    app.log("Пианино выключено");
  };
  
  init() { 
     this.piano.addEventListener("mousedown", this.startKeyActive);
     this.piano.addEventListener("mousemove", this.moveKeyActive);
     this.piano.addEventListener("mouseup", this.stopKeyActive);
  }
  
 
}
 
var app = new Piano();
Добавлено через 1 час 20 минут
Я заморочился и прикрутил туда осцилограф

http://jsfiddle.net/p9t15uLo/28/
1
4 / 4 / 0
Регистрация: 04.11.2020
Сообщений: 41
20.03.2021, 11:48  [ТС]
nikolya223, Да уж, ты действительно заморочился))) Спасибо тебе большое. Ну а что в моем коде было не так? Я так понимаю, что проблема было в этой функции, а точнее в ее аргументе, и я не понял как его передать на событие.
JavaScript
1
2
3
4
5
function playAudio (data) { //start function playAudio
  const audio = document.querySelector(`audio[data-note="${data}"]`);
  audio.currentTime = 0;
  audio.play();
}
0
123 / 98 / 15
Регистрация: 02.02.2014
Сообщений: 346
20.03.2021, 19:08
У нас разный подход.
вам нет нужды вешать на каждую кнопку события, при каждом наведении всё это перебирать.
в моём примере сделано всё на боксе с клавишами. и событие mousemove.
Чем проще сделано, тем легче контролировать. Если нужно выделить текущую клавишу и снять выделение с другой. для этого есть siblings

Можно вообще не заморачиваться с dataset, а прямо к элементам октавы добавлять ссылки на элементы.

Добавлено через 11 минут
Ну селектор вроде верно написан, по другому так 'audio[data-note="' + data +'"]'


Тут сложно на глаз определить. надо щупать и отладку через console.log делать
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.03.2021, 19:08
Помогаю со студенческими работами здесь

Событие не зажатой GUI кнопки unity3d 4.6
Приветствую! Создаю игру, нужно сделать GUI кнопку. В Unity 4.6 можно &quot;визуально&quot; создавать GUI элементы, и назначать им функции. ...

Событие клика ЛКМ по другому приложению
Нужно поймать событие клика мышкой НЕ ПО НАШЕЙ ФОРМЕ, ничего дельного в интеренете и на форуме не нашел

Как отловить событие перемещения курсора при зажатой левой кнопке мыши
Искал на форуме не нашел как можно реализовать такую штуку? Хочу отловить событие перемещения курсора при зажатой левой кнопке мыши. К...

Автоклик ЛКМ пока зажат ЛКМ
Такая фигня: можно ли сделать нажатие ЛКМ до тех пор, пока ЛКМ зажат? Могу сделать такую штуку на XBUTTON2 / XBUTTON1, но не могу сделать...

По нажатию ЛКМ рисовать эллипс, а по нажатию Shift+ЛКМ - окружность
Как сделать так что бы например по нажатию лкм рисовался эллипс а по нажатию шифт+лкм только круг


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной записи. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
Контроль уникальности заводского номера - вариант №2
Maks 24.03.2026
В отличие от предыдущего варианта добавлено прерывание циклов, также добавлены новые переменные для сохранения контекста ошибки перед прерыванием цикла: Процедура ПередЗаписью(Отказ, РежимЗаписи,. . .
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-text-sdl3-c. zip finish-text-sdl3-cpp. zip
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло. Но на выплатах по больничным это. . .
Контроль уникальности заводского номера - вариант №1
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере документа выдачи шин для спецтехники с табличной частью в конфигурации КА2. Данные берутся из регистра сведений, по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru