一個新的API出來了。 HTML5 (很快)將支援使用者裝置振動。這明顯是很有趣的事情,例如它可以使用者觸發提醒,提升遊戲體驗,下面小編給大家整理javascript手機震動api,需要的朋友可以參考下。
現代瀏覽器提供的新的API越來越傾向於行動手機應用,而不是傳統的桌面應用,例如 javascript地理位置資訊API 。另外一個只針對手機應用的JavaScript API就是 振動(Vibration) API 。很明顯,這個API就是允許mobile程式設計師使用JavaScript呼叫手機的震動功能,並且能設定震動的方式和長度。
判斷瀏覽器對振動API的支援情況
一個好的習慣就是在使用之前要檢查一下當前你的應用環境、瀏覽器是否支援振動API 。以下就是偵測的方法:
程式碼如下:
// Standards ftw! var supportsVibrate = "vibrate" in navigator;
在 window.navigator 物件裡就只有一個關於振動的API: vibrate 。
振動API基礎應用
這個navigator.vibrate 函數可以接受一個數字參數,也可以接受一個數字數組,當使用數組參數時,奇數位的數值是震動秒數,偶數位為等待秒數。
// 振動1秒
navigator.vibrate(1000);
// 振動多次
// 參數分別是震動3秒,等待2秒,然後振動1秒
navigator.vibrate([3000, 2000, 1000]);
如果想停止震動,你只需要向navigator.vibrate 方法裡傳入0,或一個空數組:
// 停止振動
navigator.vibrate(0); navigator.vibrate([]);
需要振動
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); }
需要振動