Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 22.01.2020
Сообщений: 9

Голосовое управление объектом

03.05.2022, 18:08. Показов 750. Ответов 3
Метки html (Все метки)

Студворк — интернет-сервис помощи студентам
При включении "БЕГУНКА" должно включаться голосовое управление обьектом, но оно не включается, в каком моменте проблема в коде?
Задание: С использованием сервиса распознавания голоса и набора голосовых команд, например "вверх-вниз-середина", "влево-вправо-центр", "ближе-дальше-начало", обеспечить управление этим объектом.

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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
<!DOCTYPE html>
<html>
<meta charset="UTF-8">
 
<title>Mayatnik</title>
<link rel="stylesheet" href="main.css">
<h1 style='text-align: center'> Управляй Шариком </h1>
<h2 style='text-align: center'> Команды: Вверх, вниз, влево, напрaво. </h2>
<div class="switch">
  <input type="checkbox">
</div>
 
<body>
 
  <style>
    #canvas {
      display: block;
      margin: 0 auto;
      padding: 0;
    }
    
    body {
      background-image: url(987396a6d03978b643eddd97f0daf8f2.jpg);
      background-repeat: repeat-x, repeat-x;
      background-position-x: 40%;
      background-position-y: 5%;
      background-size: 100%;
    }
    
    {
      margin: 0;
      padding: 0;
      background: #141414;
    }
    
    .switch {
      position: absolute;
      display: flex;
      top: 53%;
      left: 50%;
      transform: translate(-50%, -50%);
    }
    
    input[type="checkbox"] {
      position: relative;
      width: 80px;
      height: 30px;
      -webkit-appearance: none;
      outline: none;
      background: #fff0f5;
      border-radius: 20px;
      transition: 0.5s;
    }
    
    input:checked[type="checkbox"] {
      background: #faafc4;
    }
    
    input[type="checkbox"]:before {
      content: '';
      position: absolute;
      width: 40px;
      height: 40px;
      transform: scale(1.1);
      border-radius: 50%;
      top: -5px;
      left: 0;
      background: #faafc4;
      transition: 0.5s;
    }
    
    input:checked[type="checkbox"]:before {
      background: #f77ea0;
      left: 40px;
    }
  </style>
 
</body>
 
<div id="center">
  <canvas id=canvas width="350" height="350"></canvas>
</div>
 
<script type="text/javascript">
  var recognizer = new webkitSpeechRecognition();
  recognizer.interimResults = true;
  recognizer.lang = "ru-Ru";
  recognizer.onresult = function(event) {
    var result = event.results[event.resultIndex];
 
    if (result.isFinal && result[0].transcript == "влево") {
      let timerId = setInterval(function() {
 
        draw();
 
        if (x > 0) {
          x = x - 2;
        } else clearTimeout(timerId);
      }, 20);
    }
    if (result.isFinal && result[0].transcript == "вверх") {
      let timerId = setInterval(function() {
 
        draw();
 
        if (y > 0) {
          y = y - 2;
        } else clearTimeout(timerId);
      }, 20);
    }
    if (result.isFinal && result[0].transcript == "вниз") {
      let timerId = setInterval(function() {
 
        draw();
 
        if (y < 350) {
          y = y + 2;
        } else clearTimeout(timerId);
      }, 20);
    }
    if (result.isFinal && result[0].transcript == "направо") {
      let timerId = setInterval(function() {
 
        draw();
 
        if (x < 350) {
          x = x + 2;
        } else clearTimeout(timerId);
      }, 20);
    } else {
      console.log('Промежуточный результат:', result[0].transcript);
    }
  };
 
  function speech() {
    recognizer.start();
  }
</script>
 
<script type="text/javascript">
  var canvas = document.getElementById("canvas");
  var context = canvas.getContext("2d");
 
  var x = 175;
  var y = 175;
 
  requestAnimationFrame(draw);
 
 
  function draw() {
 
    var size = Math.min(canvas.width, canvas.height);
    var rBall = size * 0.03;
 
 
    context.clearRect(0, 0, canvas.width, canvas.height);
    drawBg(context, canvas.width, canvas.height);
    drawBase(context, canvas.width);
 
    drawBall(context, x, y, rBall);
 
    requestAnimationFrame(draw);
  }
 
  function drawBg(context, w, h) {
    context.fillStyle = "rgba(255,255,255,0.51)"
    context.fillRect(0, 0, w, h);
    context.fillStyle = "yellow";
  }
 
  function drawBase(context, w) {
    context.save();
    context.moveTo(0, 2);
    context.lineTo(w, 2);
    context.restore();
  }
 
  function drawBall(context, x, y, rBall) {
    context.save();
    context.beginPath();
    context.arc(x, y, rBall, 0, Math.PI * 2);
    context.fill();
    context.restore();
  }
</script>
 
</html>
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.05.2022, 18:08
Ответы с готовыми решениями:

Голосовое управление
Мне надо добавить голосовое управление в игру, ну хотя бы 2 команды, библиотек в интернете куча, уже голова кругом идет. Если вам несложно...

Голосовое управление
Здравствуйте уважаемые программисты возможно ли на vb.net написать программу которая управляется голосом.Например в TextBox вводит цифры...

Голосовое управление
Здравствуйте, никто не знает можно ли сделать голосовое управление плеером, word, калькулятором и всякое такое при помощи C#?

3
Юзер с абсолютным слухом
 Аватар для Опан
709 / 489 / 195
Регистрация: 17.12.2010
Сообщений: 1,428
04.05.2022, 00:08
В роде выходной массив должен быть двухмерным:
JavaScript
1
console.log(event.results[0][0].transcript);
В общем, возьмите на вооружение этот пример там всё чётко работает

Добавлено через 5 минут
Правда, в этом примере используют query там, где можно обойтись без него, что я сам не очень приветствую.
0
Юзер с абсолютным слухом
 Аватар для Опан
709 / 489 / 195
Регистрация: 17.12.2010
Сообщений: 1,428
06.05.2022, 21:40
Добавьте в Ваш код такой запуск/останов:
JavaScript
1
2
3
document.querySelector("input").onclick = function(){
    this.checked ? recognizer.start() : recognizer.stop();
}
Ещё нужно все clearTimeout() заменить на clearInterval().
0
0 / 0 / 0
Регистрация: 22.01.2020
Сообщений: 9
10.05.2022, 18:07  [ТС]
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
<!DOCTYPE html>
<html>
<meta charset="UTF-8">
 
<title>Mayatnik</title>
<link rel="stylesheet" href="main.css">
<h1 style='text-align: center'> Управляй Шариком </h1>
<h2 style='text-align: center'> Команды: Вверх, вниз, влево, напрaво. </h2>
<div class="switch">
  <input type="checkbox">
</div>
 
<body>
 
  <style>
    #canvas {
      display: block;
      margin: 0 auto;
      padding: 0;
    }
    
    body {
      background-image: url(987396a6d03978b643eddd97f0daf8f2.jpg);
      background-repeat: repeat-x, repeat-x;
      background-position-x: 40%;
      background-position-y: 5%;
      background-size: 100%;
    }
    
    {
      margin: 0;
      padding: 0;
      background: #141414;
    }
    
    .switch {
      position: absolute;
      display: flex;
      top: 53%;
      left: 50%;
      transform: translate(-50%, -50%);
    }
    
    input[type="checkbox"] {
      position: relative;
      width: 80px;
      height: 30px;
      -webkit-appearance: none;
      outline: none;
      background: #fff0f5;
      border-radius: 20px;
      transition: 0.5s;
    }
    
    input:checked[type="checkbox"] {
      background: #faafc4;
    }
    
    input[type="checkbox"]:before {
      content: '';
      position: absolute;
      width: 40px;
      height: 40px;
      transform: scale(1.1);
      border-radius: 50%;
      top: -5px;
      left: 0;
      background: #faafc4;
      transition: 0.5s;
    }
    
    input:checked[type="checkbox"]:before {
      background: #f77ea0;
      left: 40px;
    }
  </style>
 
</body>
 
<div id="center">
  <canvas id=canvas width="350" height="350"></canvas>
</div>
 
<script type="text/javascript">
  var recognizer = new webkitSpeechRecognition();
  recognizer.interimResults = true;
  recognizer.lang = "ru-Ru";
  recognizer.onresult = function(event) {
    var result = event.results[event.resultIndex];
 
    if (result.isFinal && result[0].transcript == "влево") {
      let timerId = setInterval(function() {
 
        draw();
 
        if (x > 0) {
          x = x - 2;
        } else clearInterval(timerId);
      }, 20);
    }
    if (result.isFinal && result[0].transcript == "вверх") {
      let timerId = setInterval(function() {
 
        draw();
 
        if (y > 0) {
          y = y - 2;
        } else clearInterval(timerId);
      }, 20);
    }
    if (result.isFinal && result[0].transcript == "вниз") {
      let timerId = setInterval(function() {
 
        draw();
 
        if (y < 350) {
          y = y + 2;
        } else clearInterval(timerId);
      }, 20);
    }
    if (result.isFinal && result[0].transcript == "направо") {
      let timerId = setInterval(function() {
 
        draw();
 
        if (x < 350) {
          x = x + 2;
        } else clearInterval(timerId);
      }, 20);
    } else {
      console.log('Промежуточный результат:', result[0].transcript);
    }
  };
 
  function speech()  
  
  document.querySelector("input").onclick = function(){
    this.checked ? recognizer.start() : recognizer.stop();
}
</script>
 
<script type="text/javascript">
  var canvas = document.getElementById("canvas");
  var context = canvas.getContext("2d");
 
  var x = 175;
  var y = 175;
 
  requestAnimationFrame(draw);
 
 
  function draw() {
 
    var size = Math.min(canvas.width, canvas.height);
    var rBall = size * 0.03;
 
 
    context.clearRect(0, 0, canvas.width, canvas.height);
    drawBg(context, canvas.width, canvas.height);
    drawBase(context, canvas.width);
 
    drawBall(context, x, y, rBall);
 
    requestAnimationFrame(draw);
  }
 
  function drawBg(context, w, h) {
    context.fillStyle = "rgba(255,255,255,0.51)"
    context.fillRect(0, 0, w, h);
    context.fillStyle = "yellow";
  }
 
  function drawBase(context, w) {
    context.save();
    context.moveTo(0, 2);
    context.lineTo(w, 2);
    context.restore();
  }
 
  function drawBall(context, x, y, rBall) {
    context.save();
    context.beginPath();
    context.arc(x, y, rBall, 0, Math.PI * 2);
    context.fill();
    context.restore();
  }
</script>
 
</html>
Cделал по вашей рекомендации, эффекта ноль. Может что напутал?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.05.2022, 18:07
Помогаю со студенческими работами здесь

Голосовое управление
Я хочу написать код для игры. Суть такова я говорю команду он начинает записывать цифру пример 328 после он пишит в чат команду. я не...

Голосовое управление
Здравствуйте! Помогите разобраться. Раньше писал приложения для голосового управления на C#. На официальном сайте Майкрософт скачивал файлы...

Голосовое управление
Подскажите, пожалуйста, что не так делаю. Вываливает такую ошибку: &quot;Необработанное исключение типа...

Голосовое управление
Доброго времени суток! Как и на чем можно сделать голосовое управление приложениями и устройствами? Например отключение/ включение wi-fi,...

Голосовое управление
Привет всем. Захотелось создать прогу с голосовым управлением. Как?) не знаю как сделать, что бы прога после фразы, поняла, что надо...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru