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

Голосовое сообщение при клике мыши в определённой области картинки в игре

02.02.2019, 12:47. Показов 3298. Ответов 23
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте! Игра работает! Подскажите, пожалуйста, как сделать так, чтобы клик мыши В ОПРЕДЕЛЁННУЮ ОБЛАСТЬ КАРТИНКИ сопровождался определённым голосовым сообщением?
PHP/HTML
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
<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>Геометрия для малышей</title>
</head>
<body>
 <h1 id="heading">Найди круг!</h1>
<img  id="map" width=400 height=400
 src=../../imagesgames/igra1.gif> <br>
  <p id="distance"></p>
 <script src="https://code.jquery.com/jquery-2.1.0.js"></script>
 <script>
 // Вычислить расстояние от клика (event) до круга (target)
 var getDistance = function (event, target) {
 var diffX = event.offsetX - target.x;
 var diffY = event.offsetY - target.y;
 return Math.sqrt((diffX * diffX) + (diffY * diffY));
 };
 // Получить для расстояния строку подсказки
 var getDistanceHint = function (distance) {
 if (distance < 152) {
 return "УРА!!! ПОБЕДА!!!";
 } else
if (distance < 200) {
 return "ОЙ! ОШИБОЧRА! ПОПРОБУЙ ЕЩЁ РАЗ!";
 } else if (distance < 320) {
 return "ОЙ! ОШИБОЧКА! ПОПРОБУЙ ЕЩЁ РАЗ!";
 } else {
 return "ОЙ! ОШИБОЧКА! ПОПРОБУЙ ЕЩЁ РАЗ!";
 }
 };
 // Создаем переменные
var width = 400;
 var height = 400;
 var clicks = 0;
 // Позиция круга
var target = {
 x: 252,
 y:84
 };
 // Добавляем элементу img обработчик клика
$("#map").click(function (event) {
 clicks++;
  // Получаем расстояние от места клика до круга
 var distance = getDistance(event, target);
 // Преобразуем расстояние в подсказку
 var distanceHint = getDistanceHint(distance);
 // Записываем в элемент #distance новую подсказку
$("#distance").text(distanceHint);
 // Если клик был достаточно близко, поздравляем с победой
 if (distance < 150) {
 alert("КРУГ НАЙДЕН! Сделано кликов: " + clicks );
 setTimeout('window.location="NaydiKrug2.html"',5000);
 }
 });
 </script>
 
</body>
</html>
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.02.2019, 12:47
Ответы с готовыми решениями:

В Eclipse(Oxygen) при правом клике мыши в любой области открытого файла возникает 1-минутное зависание с выводом ошибки
Добрый день, уважаемые форумчане. В Eclipse(Oxygen) при правом клике мыши в любой области открытого файла возникает 1-минутное...

Вывести сообщение при клике на 2 одинаковых картинки
привет всем. динамически в массиве создаю 36 изображений. у каждого изображения есть своя копия. никак не могу понять, как сделать...

Считывание нажатия мыши в определенной области
Нужно определить в какой конкретно области окна нажата мышь, при вызове .contain() visual studio выдаёт кучу ошибок. Помогите пожалуйста. ...

23
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
02.02.2019, 14:37
Лучший ответ Сообщение было отмечено Марина29 как решение

Решение

Марина29,
Цитата Сообщение от Марина29 Посмотреть сообщение
Подскажите, пожалуйста, как сделать так,
пожалуйста, один из вариантов - создаете на странице скрытый <audio>, вешаете обработчик click на элемент, в нём сверяете координаты мыши и элементы относительно документа, при совпадении audio.play().

пример - https://jsfiddle.net/Qwerty_Wasd/d81mvqLa/
При клике только на смайл с сердечками будет воспроизводиться аудио.
HTML5
1
2
3
4
<audio id='audio' src="http://developer.mozilla.org/@api/deki/files/2926/=AudioTest_(1).ogg">
  Ваш браузер не поддерживает <code>audio</code> элемент. 
</audio>
<img id="image" src="https://businessviews.com.ua/files/news_tape/images/17/15/picture_pochemu-smajliki-v-r_1715_s1.png" alt="">
JavaScript
1
2
3
document.getElementById('image').addEventListener('click', e => {
  if( e.pageY > 50 && e.pageY < 300 && e.pageX > 50 && e.pageX < 300) document.getElementById('audio').play();
});
1
0 / 0 / 0
Регистрация: 02.02.2019
Сообщений: 10
02.02.2019, 15:38  [ТС]
Спасибо, но почему-то, когда Ваши координаты меняю на свои, не работает. А с Вашими всё работает.
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
02.02.2019, 15:49
Марина29,
Цитата Сообщение от Марина29 Посмотреть сообщение
меняю на свои
а по Вашим координатам находится тот участок, что должен откликаться на событие? Как Вы их высчитываете?

Добавлено через 6 минут
Марина29, для начального изучения вопроса -
http://learn.javascript.ru/coordinates-document
https://learn.javascript.ru/mo... -clientx-y
0
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,968
Записей в блоге: 233
02.02.2019, 18:19
Марина29,Open the "Ch01" folder in the source code and you will see how to use the <audio> element and another useful things.
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
03.02.2019, 00:16
8Observer8, hi That exp's you presented -
Цитата Сообщение от 8Observer8 Посмотреть сообщение
Pro HTML5 Games - 2nd Edition - A.R. Shankar
Source code: https://github.com/apress/pro-html5-games-17
surely good , butn't relevant yet for topicstarter
1
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,968
Записей в блоге: 233
03.02.2019, 00:44
Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
butn't relevant yet for topicstarter
Yes, especially If she is afraid of English. But if she open first example in GitHub she will see some good things. My job is to offer.
1
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,968
Записей в блоге: 233
03.02.2019, 00:50
For example, she will see the code:
PHP/HTML
1
2
3
4
5
        <audio controls="controls">
            <source src="music.ogg" type="audio/ogg" />
            <source src="music.mp3" type="audio/mpeg" />
            Your browser does not support HTML5 Audio. Please shift to a newer browser.
        </audio>
And if she just see a few pages in the book she will see this table:



I think it is useful information. But it is only a chance then she will be interesting for that.
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
03.02.2019, 01:06
8Observer8, https://caniuse.com/# - всегда актуально. Мы ведь на русскоязычном форуме, давайте соответствовать)) А то нам сейчас атата сделают
1
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,968
Записей в блоге: 233
03.02.2019, 01:16

Не по теме:

Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
Мы ведь на русскоязычном форуме, давайте соответствовать)) А то нам сейчас атата сделают
You can see my messages. I didn't use Russian from beginning of the year and I will use English only in 2019. I promised to myself. The rule of the forum 1.4 allows me to use English.



Добавлено через 3 минуты
Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
https://caniuse.com/#
Edge supports OGG since 13 November 2018. Good. But IE 11 supports only MP3.
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
03.02.2019, 01:23

Не по теме:

Oh, ok. Sorry, Well... then go to the branch more often JS. I'll practice :)



Цитата Сообщение от 8Observer8 Посмотреть сообщение
Edge supports OGG since 13 November 2018. Good. But IE 11 supports only MP3.
and a....? Why did i need that ? I have it That's need TS.
0
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,968
Записей в блоге: 233
03.02.2019, 01:30
Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
I have it That's need TS.
I don't understand you. What do you have? Internet Explorer 11? IE 11 does not support OGG. What is TS?
1
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
03.02.2019, 01:34
8Observer8, sorry -
TS - i meen topicstarter
Цитата Сообщение от 8Observer8 Посмотреть сообщение
What do you have
i know that
Цитата Сообщение от 8Observer8 Посмотреть сообщение
Edge supports OGG since 13 November 2018. Good. But IE 11 supports only MP3.
1
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,968
Записей в блоге: 233
03.02.2019, 01:49
Maybe TS won't understand us but I want to add some useful features in her code from here tomorrow. It will be in borders of the theme.

Не по теме:

Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
TS - i meen topicstarter
I think "I" must be in uppercase. Let's try to use corrent grammar. But if you want you can write "i". I won't be undry :)

1
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
03.02.2019, 01:56
8Observer8,
Цитата Сообщение от 8Observer8 Посмотреть сообщение
I think "I" must be in uppercase.
thx(thanks)
I'll try. Forgotten - wasn't practice
1
0 / 0 / 0
Регистрация: 02.02.2019
Сообщений: 10
03.02.2019, 05:44  [ТС]
ДАННЫЙ ВОПРОС РЕШЁН! КАК ЗАКРЫТЬ ЭТУ ТЕМУ?
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
03.02.2019, 05:48
Марина29, здесь темы не закрывают. Помимо Вас, сюда придут другие люди с похожим вопросом. Знания останутся для них. И кричать(капс) было не обязательно
0
0 / 0 / 0
Регистрация: 02.02.2019
Сообщений: 10
03.02.2019, 06:01  [ТС]
Хорошо, скажите, как отредактировать тему?
0
Эксперт JSЭксперт HTML/CSS
2151 / 1496 / 651
Регистрация: 16.04.2016
Сообщений: 3,696
03.02.2019, 06:20
Марина29, если нет кнопки править - уже никак. Напишите модераторам ветки. Объясните причину. Если причина конструктивна и редактирование\удаление закономерно и отвечает концепции форума, то думаю модератор пойдет Вам навстречу.
0
9933 / 2936 / 494
Регистрация: 05.10.2013
Сообщений: 7,968
Записей в блоге: 233
03.02.2019, 13:14
Цитата Сообщение от Qwerty_Wasd Посмотреть сообщение
пример - https://jsfiddle.net/Qwerty_Wasd/d81mvqLa/
При клике только на смайл с сердечками будет воспроизводиться аудио.
Why the audio is played only with second click and with pause?

Добавлено через 2 минуты
I want to improve the code of topic starter from the first message of the theme.

Добавлено через 59 секунд
Please, do not close the theme.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.02.2019, 13:14
Помогаю со студенческими работами здесь

Программное нажатие мыши в игре в определнной области
Всем доброго времени суток! На Windows Forms имею приложение, которое по определенному алгоритму нажимает кнопки клавиатуры в игре на...

Вывод текста по клику мыши в определенной области (Си)
В курсовой нужно вывести определенную информацию на экран по клику мыши в определенной области. Вроде все правильно, но что-то не работает....

Печать из picturebox определенной области картинки
как распечатать картинку которая нарисована в picturebox при этом не всю картинку а определенный ее кусок

Плавает курсор мыши. Задержка мыши при игре в шутеры (игры)
Мучаюсь с проблемой две недели. Совершенно запутался и кажется начинаю терять нервные клетки. Попробую описать проблему детальнее, чтобы...

Сделать так, что бы форма отвечала на нажатие мыши только в определенной области
В общем как сделать так, что бы форма отвечала на нажатие мыши только в определенной области. В другом месте её как бы нет, но она есть, и...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru