From 4dd2f78f50aee4daebe5c80d1f0d26d044457732 Mon Sep 17 00:00:00 2001 From: Benjamin Ver Date: Mon, 28 Sep 2020 12:26:09 +0200 Subject: [PATCH] debouncing --- script/resultHandling.js | 45 +++++++++++++++++++++++++++------------- 1 file changed, 31 insertions(+), 14 deletions(-) diff --git a/script/resultHandling.js b/script/resultHandling.js index 550ce85..005e9a8 100644 --- a/script/resultHandling.js +++ b/script/resultHandling.js @@ -1,7 +1,3 @@ -// todo script/VoskJS.js inladen - -// const langModel = "model-nl.tar.gz"; -// const allWords = ['volgende', 'vorige']; const callbacks = []; const allWords = [] var eventWordMap; @@ -28,20 +24,40 @@ window.iridium.onExternalNavigate = (callback) => { }; +// source: https://davidwalsh.name/javascript-debounce-function +function debounce(func, wait, immediate) { + var timeout; + return function() { + var context = this, args = arguments; + var later = function() { + timeout = null; + if (!immediate) func.apply(context, args); + }; + var callNow = immediate && !timeout; + clearTimeout(timeout); + timeout = setTimeout(later, wait); + if (callNow) func.apply(context, args); + }; +}; + + function handleResult(res, handleIt, reset=null) { if (typeof reset == "function") { reset(); } var wordHandled = false; - words = res.result; - words.forEach((x) => { - if (allWords.includes(x.word)) { - wordHandled = true; - handleIt(x.word, x.conf); - } - }); + if (typeof res.result != undefined) { + // words = res.result; + res.result.forEach((x) => { + if (allWords.includes(x.word)) { + wordHandled = true; + handleIt(x.word, x.conf); + } + }); + } } + function sendCommand(w, c) { if (c >= .5) { const action = eventWordMap[w]; @@ -54,8 +70,9 @@ function sendCommand(w, c) { thisRec = new VoskJS.Recognizer(langModel); thisRec.onresult = result => { - if (result.result) { - handleResult(result, sendCommand); - } + debounce(function() { handleResult(result, sendCommand) }, 200); + // if (result.result) { + // handleResult(result, sendCommand); + // } } thisRec.getActive().then(active => thisRec.setActive(!active)); \ No newline at end of file