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

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

02.02.2019, 12:47. Просмотров 1985. Ответов 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
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
02.02.2019, 12:47
Ответы с готовыми решениями:

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

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

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

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

23
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
02.02.2019, 14:37 2
Лучший ответ Сообщение было отмечено Марина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  [ТС] 3
Спасибо, но почему-то, когда Ваши координаты меняю на свои, не работает. А с Вашими всё работает.
0
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
02.02.2019, 15:49 4
Марина29,
Цитата Сообщение от Марина29 Посмотреть сообщение
меняю на свои
а по Вашим координатам находится тот участок, что должен откликаться на событие? Как Вы их высчитываете?

Добавлено через 6 минут
Марина29, для начального изучения вопроса -
http://learn.javascript.ru/coordinates-document
https://learn.javascript.ru/mo... -clientx-y
0
4187 / 2294 / 387
Регистрация: 05.10.2013
Сообщений: 6,393
Записей в блоге: 177
02.02.2019, 18:19 5
Марина29,Open the "Ch01" folder in the source code and you will see how to use the <audio> element and another useful things.
0
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
03.02.2019, 00:16 6
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
4187 / 2294 / 387
Регистрация: 05.10.2013
Сообщений: 6,393
Записей в блоге: 177
03.02.2019, 00:44 7
Цитата Сообщение от 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
4187 / 2294 / 387
Регистрация: 05.10.2013
Сообщений: 6,393
Записей в блоге: 177
03.02.2019, 00:50 8
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
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
03.02.2019, 01:06 9
8Observer8, https://caniuse.com/# - всегда актуально. Мы ведь на русскоязычном форуме, давайте соответствовать)) А то нам сейчас атата сделают
1
4187 / 2294 / 387
Регистрация: 05.10.2013
Сообщений: 6,393
Записей в блоге: 177
03.02.2019, 01:16 10

Не по теме:

Цитата Сообщение от 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
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
03.02.2019, 01:23 11

Не по теме:

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
4187 / 2294 / 387
Регистрация: 05.10.2013
Сообщений: 6,393
Записей в блоге: 177
03.02.2019, 01:30 12
Цитата Сообщение от 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
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
03.02.2019, 01:34 13
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
4187 / 2294 / 387
Регистрация: 05.10.2013
Сообщений: 6,393
Записей в блоге: 177
03.02.2019, 01:49 14
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
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
03.02.2019, 01:56 15
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  [ТС] 16
ДАННЫЙ ВОПРОС РЕШЁН! КАК ЗАКРЫТЬ ЭТУ ТЕМУ?
0
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
03.02.2019, 05:48 17
Марина29, здесь темы не закрывают. Помимо Вас, сюда придут другие люди с похожим вопросом. Знания останутся для них. И кричать(капс) было не обязательно
0
0 / 0 / 0
Регистрация: 02.02.2019
Сообщений: 10
03.02.2019, 06:01  [ТС] 18
Хорошо, скажите, как отредактировать тему?
0
dev - investigator
Эксперт JSЭксперт HTML/CSS
2127 / 1473 / 648
Регистрация: 16.04.2016
Сообщений: 3,688
03.02.2019, 06:20 19
Марина29, если нет кнопки править - уже никак. Напишите модераторам ветки. Объясните причину. Если причина конструктивна и редактирование\удаление закономерно и отвечает концепции форума, то думаю модератор пойдет Вам навстречу.
0
4187 / 2294 / 387
Регистрация: 05.10.2013
Сообщений: 6,393
Записей в блоге: 177
03.02.2019, 13:14 20
Цитата Сообщение от 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
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.02.2019, 13:14

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь или здесь.

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.