Фоновая вибрация Tizen
Я разрабатываю приложение для Samsung Gear S2 (веб) с таймером, который вибрирует, когда время заканчивается. Что мне нужно сделать, чтобы мое приложение могло вибрировать, даже если оно работает в фоновом режиме?
1 ответ
В общем, фоновая вибрация (из выключенного состояния экрана) не доступна напрямую для веб-приложений, если вы не используете Alarm API или Notification.
Но временную фоновую вибрацию можно легко обойти, используя Power API и веб-работников. Я делюсь примером кода:
main.js
window.onload = function() {
document.addEventListener('tizenhwkey', function(e) {
if (e.keyName === "back") {
try {
tizen.application.getCurrentApplication().hide();
}catch (ignore) {}
}
});
var mainPage = document.querySelector('#main');
mainPage.addEventListener("click", function() {
var contentText = document.querySelector('#content-text');
var worker; //web worker
worker = new Worker("js/worker.js"); //load from directory
worker.onmessage = function(event) { //receive data from worker
tizen.power.turnScreenOn(); // forcefully turn the screen on
setTimeout(function (){
contentText.innerHTML = event.data; // time counter
navigator.vibrate(1000);
}, 500); // just being safe (vibrate after screen is on)
};
});
};
worker.js
var i=0;
function timedCount() {
i=i+1;
postMessage(i); //send data
setTimeout("timedCount()",5000); // set vibration interval (or use specific time)
}
timedCount();
добавьте эти строки в ваш config.xml
<tizen:privilege name="http://tizen.org/privilege/power"/>
<tizen:setting background-support="enable" encryption="disable" hwkey-event="enable"/>
Когда фоновая поддержка включена, приложение будет реагировать при минимальном использовании, когда вы обращаетесь к веб-работникам. Использование getCurrentApplication(). Hide() вместо getCurrentApplication(). Exit() для события back key сделает эту задачу за вас.
Проверьте Руководство по вибрации для различных типов вибрации.