js如何實現手機呼叫震動功能

admin發表於2017-02-23
本章節介紹一下,如何實現手機呼叫震動功能。

最好事先檢查一下當前瀏覽器是否支援震動功能,下面就是檢測的方法:

[JavaScript] 純文字檢視 複製程式碼
// Standards ftw!
var supportsVibrate = "vibrate" in navigator;

在window.navigator物件裡就只有一個關於振動的API:vibrate。

振動API基礎應用:

navigator.vibrate函式可以接受一個數字引數,也可以接受一個數字陣列。

當使用陣列引數時,奇數位的數值是震動秒數,偶數位為等待秒數。

[JavaScript] 純文字檢視 複製程式碼
// 振動1秒
navigator.vibrate(1000);
  
// 振動多次
// 引數分別是震動3秒,等待2秒,然後振動1秒
navigator.vibrate([3000, 2000, 1000]);

如果想停止震動,你只需要向navigator.vibrate方法裡傳入0,或一個空陣列:

[JavaScript] 純文字檢視 複製程式碼
// 停止振動
navigator.vibrate(0);
navigator.vibrate([]);

需要提醒的是,對navigator.vibrate方法的呼叫並不會引起手機迴圈振動;當引數是一個數字時,振動之後發生一次,然後就停止下來。當引數是陣列時,震動會按陣列裡的值震動,然後就停止振動。

持續震動:

我們可以簡單的使用setInterval 和 clearInterval 方法產生讓手機持續震動的效果:

[JavaScript] 純文字檢視 複製程式碼
var vibrateInterval;
  
// Starts vibration at passed in level
function startVibrate(duration) {
 navigator.vibrate(duration);
}
  
// Stops vibration
function stopVibrate() {
 // Clear interval and stop persistent vibrating 
 if(vibrateInterval) clearInterval(vibrateInterval);
 navigator.vibrate(0);
}
  
// Start persistent vibration at given duration and interval
// Assumes a number value is given
function startPeristentVibrate(duration, interval) {
 vibrateInterval = setInterval(function() {
 startVibrate(duration);
 }, interval);
}

這段程式碼只是針對振動引數是一個數字的情況,如果引數是陣列,你還需要計算一下它的總共持續時間,然後根據它的特徵來進行迴圈。

使用振動(Vibration) API的場景:

這個API顯然是針對移動手機裝置的。當開發手機WEB移動應用時,它是一個很好的警示工具,當在開發Web遊戲或多媒體應用時,這個振動功能更是不可或缺的好技術。比如說,當使用者在用一個手機玩你的WEB遊戲時,當遊戲中發生爆炸,而你讓手機也跟隨著振動,是不是一種很出色的使用者體驗。

相關文章