javascript實現手機震動API代碼_javascript技巧

來源:互聯網
上載者:User

現代瀏覽器裡提供的新的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 levelfunction startVibrate(duration) {navigator.vibrate(duration);}// Stops vibrationfunction 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 givenfunction startPeristentVibrate(duration, interval) {vibrateInterval = setInterval(function() {startVibrate(duration);}, interval);}

上面的這段代碼只是針對震動參數是一個數位情況,如果參數是數組,你還需要計算一下它的總共期間,然後根據它的特徵來進行迴圈。

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

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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.