欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript實(shí)現(xiàn)手機(jī)震動(dòng)API代碼

 更新時(shí)間:2015年08月05日 12:07:52   投稿:mrr  
一個(gè)新的API出來(lái)了。HTML5 (很快)將支持用戶(hù)設(shè)備振動(dòng)。這明顯是很有趣的事情,比如它可以用戶(hù)觸發(fā)提醒,提升游戲體驗(yàn),下面小編給大家整理javascript手機(jī)震動(dòng)api,需要的朋友可以參考下

現(xiàn)代瀏覽器里提供的新的API越來(lái)越傾向于移動(dòng)手機(jī)應(yīng)用,而不是傳統(tǒng)的桌面應(yīng)用,比如 javascript地理位置信息API 。另外一個(gè)只針對(duì)手機(jī)應(yīng)用的JavaScript API就是 振動(dòng)(Vibration) API 。很明顯,這個(gè)API就是允許mobile程序員使用JavaScript調(diào)用手機(jī)的振動(dòng)功能,并且能設(shè)定振動(dòng)的方式和時(shí)長(zhǎng)。

判斷瀏覽器對(duì)振動(dòng)API的支持情況
一個(gè)好的習(xí)慣就是在使用之前要檢查一下當(dāng)前你的應(yīng)用環(huán)境、瀏覽器是否支持振動(dòng)API。下面就是檢測(cè)的方法:

復(fù)制代碼 代碼如下:

// Standards ftw!
var supportsVibrate = "vibrate" in navigator;

在 window.navigator 對(duì)象里就只有一個(gè)關(guān)于振動(dòng)的API: vibrate 。

振動(dòng)API基礎(chǔ)應(yīng)用
這個(gè) navigator.vibrate 函數(shù)可以接受一個(gè)數(shù)字參數(shù),也可以接受一個(gè)數(shù)字?jǐn)?shù)組,當(dāng)使用數(shù)組參數(shù)時(shí),奇數(shù)位的數(shù)值是震動(dòng)秒數(shù),偶數(shù)位為等待秒數(shù)。

// 振動(dòng)1秒

復(fù)制代碼 代碼如下:

navigator.vibrate(1000);

// 振動(dòng)多次
// 參數(shù)分別是震動(dòng)3秒,等待2秒,然后振動(dòng)1秒
復(fù)制代碼 代碼如下:

navigator.vibrate([3000, 2000, 1000]);

如果想停止震動(dòng),你只需要向 navigator.vibrate 方法里傳入0,或一個(gè)空數(shù)組:

// 停止振動(dòng)

復(fù)制代碼 代碼如下:

navigator.vibrate(0);
navigator.vibrate([]);

需要提醒的是,對(duì) navigator.vibrate 方法的調(diào)用并不會(huì)引起手機(jī)循環(huán)振動(dòng);當(dāng)參數(shù)是一個(gè)數(shù)字時(shí),振動(dòng)之后發(fā)生一次,然后就停止下來(lái)。當(dāng)參數(shù)是數(shù)組時(shí),震動(dòng)會(huì)按數(shù)組里的值震動(dòng),然后就停止振動(dòng)。

持續(xù)震動(dòng)
我們可以簡(jiǎn)單的使用 setInterval 和 clearInterval 方法產(chǎn)生讓手機(jī)持續(xù)震動(dòng)的效果:

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);
}

上面的這段代碼只是針對(duì)振動(dòng)參數(shù)是一個(gè)數(shù)字的情況,如果參數(shù)是數(shù)組,你還需要計(jì)算一下它的總共持續(xù)時(shí)間,然后根據(jù)它的特征來(lái)進(jìn)行循環(huán)。

使用振動(dòng)(Vibration) API的場(chǎng)景
這個(gè)API顯然是針對(duì)移動(dòng)手機(jī)設(shè)備的。當(dāng)開(kāi)發(fā)手機(jī)WEB移動(dòng)應(yīng)用時(shí),它是一個(gè)很好的警示工具,當(dāng)在開(kāi)發(fā)Web游戲或多媒體應(yīng)用時(shí),這個(gè)振動(dòng)功能更是不可或缺的好技術(shù)。比如說(shuō),當(dāng)用戶(hù)在用一個(gè)手機(jī)玩你的WEB游戲時(shí),當(dāng)游戲中發(fā)生爆炸,而你讓手機(jī)也跟隨著振動(dòng),是不是一種很出色的用戶(hù)體驗(yàn)?

你對(duì)這個(gè)JavaScript振動(dòng)API的感覺(jué)如何?是認(rèn)為它會(huì)很快流行起來(lái)?還是沒(méi)有多大用處?

相關(guān)文章

  • 取鍵盤(pán)鍵位ASCII碼的網(wǎng)頁(yè)

    取鍵盤(pán)鍵位ASCII碼的網(wǎng)頁(yè)

    取鍵盤(pán)鍵位ASCII碼的網(wǎng)頁(yè)...
    2007-07-07
  • 詳解JavaScript實(shí)現(xiàn)哈希表

    詳解JavaScript實(shí)現(xiàn)哈希表

    哈希表是一種非常重要的數(shù)據(jù)結(jié)構(gòu),幾乎所有的編程語(yǔ)言都有直接或者間接的應(yīng)用這種數(shù)據(jù)結(jié)構(gòu)。本文將為大家介紹通過(guò)JavaScript如何實(shí)現(xiàn)哈希表,以及哈希表的一些常用操作,需要的可以參考一下
    2021-12-12
  • JS實(shí)現(xiàn)兩個(gè)跨域頁(yè)面實(shí)現(xiàn)量子糾纏互動(dòng)效果

    JS實(shí)現(xiàn)兩個(gè)跨域頁(yè)面實(shí)現(xiàn)量子糾纏互動(dòng)效果

    這篇文章主要為大家詳細(xì)介紹了如何利用JavaScript實(shí)現(xiàn)兩個(gè)跨域頁(yè)面實(shí)現(xiàn)量子糾纏互動(dòng)效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • 最新評(píng)論