DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> javascript實現手機震動API代碼
javascript實現手機震動API代碼
編輯:關於JavaScript     

現代浏覽器裡提供的新的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([]);

需要提醒的是,對 navigator.vibrate 方法的調用並不會引起手機循環振動;當參數是一個數字時,振動之後發生一次,然後就停止下來。當參數是數組時,震動會按數組裡的值震動,然後就停止振動。

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

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游戲時,當游戲中發生爆炸,而你讓手機也跟隨著振動,是不是一種很出色的用戶體驗?

你對這個JavaScript振動API的感覺如何?是認為它會很快流行起來?還是沒有多大用處?

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved