欧美亚洲中文,在线国自产视频,欧洲一区在线观看视频,亚洲综合中文字幕在线观看

      1. <dfn id="rfwes"></dfn>
          <object id="rfwes"></object>
        1. 站長(zhǎng)資訊網(wǎng)
          最全最豐富的資訊網(wǎng)站

          學(xué)習(xí)JavaScript之手機(jī)振動(dòng)API

          學(xué)習(xí)JavaScript之手機(jī)振動(dòng)API

          現(xiàn)代瀏覽器里提供的新的API越來越傾向于移動(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)。

          相關(guān)學(xué)習(xí)推薦:javascript視頻教程

          判斷瀏覽器對(duì)振動(dòng)API的支持情況

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

          // 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秒 navigator.vibrate(1000);  // 振動(dòng)多次 // 參數(shù)分別是震動(dòng)3秒,等待2秒,然后振動(dòng)1秒 navigator.vibrate([3000, 2000, 1000]);

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

          // 停止振動(dòng) 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ā)生一次,然后就停止下來。當(dāng)參數(shù)是數(shù)組時(shí),震動(dòng)會(huì)按數(shù)組里的值震動(dòng),然后就停止振動(dòng)。

          持續(xù)震動(dòng)

          我們可以簡(jiǎn)單的使用setIntervalclearInterval 方法產(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ù)它的特征來進(jìn)行循環(huán)。

          使用振動(dòng)(Vibration) API的場(chǎng)景

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

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

          贊(0)
          分享到: 更多 (0)
          網(wǎng)站地圖   滬ICP備18035694號(hào)-2    滬公網(wǎng)安備31011702889846號(hào)