成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

PhoneGap API介紹:Accelerometer

移動開發
本文將介紹PhoneGap API——Accelerometer:點擊進入設備的運動傳感器采集設備在x、y、z方向上的動作。

方法

accelerometer.getCurrentAcceleration

accelerometer.watchAcceleration

accelerometer.clearWatch

參數

accelerometerSuccess

accelerometerError

accelerometerOptions

對象(只讀):

Acceleration

accelerometer.getCurrentAcceleration

返回當前沿x、y和z方向的加速度。

  1. navigator.accelerometer.getCurrentAcceleration(accelerometerSuccess, accelerometerError); 

說明

加速計是檢測設備在當前方向上所做相對運動變化(增、減量)的運動傳感器。加速計可以檢測沿X、Y和Z軸的三維運動。

加速度數據通過accelerometerSuccess回調函數返回。

支持的平臺

Android

BlackBerry WebWorks (OS 5.0或更高版本)

iPhone

簡單的范例

  1. function onSuccess(acceleration) { 
  2.     alert('Acceleration X: ' + acceleration.x + '\n' + 
  3.     'Acceleration Y: ' + acceleration.y + '\n' + 
  4.     'Acceleration Z: ' + acceleration.z + '\n' + 
  5.     'Timestamp: '      + acceleration.timestamp + '\n'); 
  6.      
  7. function onError() { 
  8.     alert('onError!'); 
  9.      
  10. navigator.accelerometer.getCurrentAcceleration(onSuccess, onError); 

完整的范例

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <title>Acceleration Example</title> 
  5.  
  6. <script type="text/javascript" charset="utf-8" src="phonegap.js"></script> 
  7. <script type="text/javascript" charset="utf-8"> 
  8.  
  9.     // 等待加載PhoneGap    
  10.     document.addEventListener("deviceready", onDeviceReady, false);  
  11.  
  12.     // PhoneGap加載完畢 
  13.     function onDeviceReady() { 
  14.         navigator.accelerometer.getCurrentAcceleration(onSuccess, onError); 
  15.     } 
  16.  
  17.     // onSuccess: 返回當前加速度數據的快照 
  18.     function onSuccess(acceleration) { 
  19.         alert('Acceleration X: ' + acceleration.x + '\n' + 
  20.             'Acceleration Y: ' + acceleration.y + '\n' + 
  21.             'Acceleration Z: ' + acceleration.z + '\n' + 
  22.             'Timestamp: '      + acceleration.timestamp + '\n'); 
  23.     } 
  24.  
  25.     // onError: 返回加速度數據失敗 
  26.     function onError() { 
  27.         alert('onError!'); 
  28.     } 
  29.      
  30. </script> 
  31. </head> 
  32. <body> 
  33.     <h1>Example</h1> 
  34.     <p>getCurrentAcceleration</p> 
  35. </body> 
  36. </html> 

iPhone的特異情況

iPhone沒有獲取在任何給定點當前加速度數據的概念。

你必須通過給定時間間隔查看加速度并獲得數據。

因此,getCurrentAcceleration函數會返回從phoneGap watchAccelerometer調用開始后的最近一個返回值。

accelerometer.watchAcceleration

在固定的時間間隔獲取沿x、y和z軸的加速度。

  1. var watchID = navigator.accelerometer.watchAcceleration(accelerometerSuccess, 
  2.                             accelerometerError, 
  3.                             [accelerometerOptions]); 

說明

加速計是檢測設備在當前方向上所做相對運動變化(增、減量)的動作傳感器。加速計可以檢測沿X、Y和Z軸的三維運動。

accelerometer.watchAcceleration每隔固定時間就獲取一次設備的當前加速度。每次取得加速度后,accelerometerSuccess回調函數會被執行。通過acceleratorOptions對象的frequency參數可以設定以毫秒為單位的時間間隔。

返回的watch id是加速度計監視周期的引用,可以通過accelerometer.clearWatch調用該watch ID以停止對加速度計的監視。

支持的平臺

Android

BlackBerry WebWorks (OS 5.0或更高版本)

iPhone

簡單的范例

  1. function onSuccess(acceleration) { 
  2.     alert('Acceleration X: ' + acceleration.x + '\n' + 
  3.     'Acceleration Y: ' + acceleration.y + '\n' + 
  4.     'Acceleration Z: ' + acceleration.z + '\n' + 
  5.     'Timestamp: '      + acceleration.timestamp + '\n'); 
  6.      
  7. function onError() { 
  8.     alert('onError!'); 
  9.      
  10. var options = { frequency: 3000 };  // 每隔3秒更新一次 
  11.      
  12. var watchID = navigator.accelerometer.watchAcceleration(onSuccess, onError, options); 

完整的范例

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <title>Acceleration Example</title> 
  5.      
  6. <script type="text/javascript" charset="utf-8" src="phonegap.js"></script> 
  7. <script type="text/javascript" charset="utf-8"> 
  8.  
  9.     // watch id 是當前“watchAcceleration”的引用 
  10.     var watchID = null
  11.      
  12.     // 等待加載PhoneGap 
  13.     document.addEventListener("deviceready", onDeviceReady, false); 
  14.      
  15.     // PhoneGap加載完畢 
  16.     function onDeviceReady() { 
  17.         startWatch(); 
  18.     } 
  19.      
  20.     // 開始監視加速度 
  21.     function startWatch() { 
  22.      
  23.     // 每隔3秒鐘更新一次加速度數據 
  24.     var options = { frequency: 3000 }; 
  25.      
  26.     watchID = navigator.accelerometer.watchAcceleration(onSuccess, onError, options); 
  27.     } 
  28.      
  29.     // 停止監視加速度 
  30.     function stopWatch() { 
  31.         if (watchID) { 
  32.             navigator.accelerometer.clearWatch(watchID); 
  33.             watchID = null
  34.         } 
  35.     } 
  36.      
  37.     // onSuccess: 獲取當前加速度數據的快照 
  38.     function onSuccess(acceleration) { 
  39.         var element = document.getElementById('accelerometer'); 
  40.         element.innerHTML = 'Acceleration X: ' + acceleration.x + '<br  />' + 
  41.                             'Acceleration Y: ' + acceleration.y + '<br  />' + 
  42.                             'Acceleration Z: ' + acceleration.z + '<br  />' + 
  43.                             'Timestamp: '      + acceleration.timestamp + '<br  />'; 
  44.     } 
  45.      
  46.     // onError: 獲取加速度失敗 
  47.     function onError() { 
  48.         alert('onError!'); 
  49.     } 
  50.      
  51. </script> 
  52. </head> 
  53. <body> 
  54.     <div id="accelerometer">Waiting for accelerometer...</div> 
  55. </body> 
  56. </html> 

iPhone的特異情況

在請求的時間間隔,PhoneGap將調用success回調指向的函數,并傳遞加速度計數據。

不過,PhoneGap將對設備的請求間隔時間限制為最小40ms,***1000ms。

例如,如果你設定每隔3秒(3000毫秒)請求一次,PhoneGap仍然每隔1秒請求一次設備,但是每隔3秒才調用一次success回調函數。

accelerometer.clearWatch

停止watch ID參數指向的加速度監視。

  1. navigator.accelerometer.clearWatch(watchID); 

watchID:由accelerometer.watchAcceleration返回的引用標識ID。

支持的平臺

Android

BlackBerry WebWorks (OS 5.0或更高版本)

iPhone

簡單的范例

  1. var watchID = navigator.accelerometer.watchAcceleration(onSuccess, onError, options); 
  2.  
  3. // ... 后續處理 ... 
  4.  
  5. navigator.accelerometer.clearWatch(watchID); 

完整的范例

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <title>Acceleration Example</title> 
  5.  
  6. <script type="text/javascript" charset="utf-8" src="phonegap.js"></script> 
  7. <script type="text/javascript" charset="utf-8"> 
  8.  
  9.     // watch id 是當前“watchAcceleration”的引用 
  10.     var watchID = null
  11.      
  12.     // 等待加載PhoneGap 
  13.     document.addEventListener("deviceready", onDeviceReady, false); 
  14.      
  15.     // PhoneGap加載完畢 
  16.     function onDeviceReady() { 
  17.         startWatch(); 
  18.     } 
  19.      
  20.     // 開始監視加速度 
  21.     function startWatch() { 
  22.      
  23.         // 每隔3秒鐘更新一次加速度數據 
  24.         var options = { frequency: 3000 }; 
  25.         watchID = navigator.accelerometer.watchAcceleration(onSuccess, onError, options); 
  26.     } 
  27.      
  28.     // 停止監視加速度 
  29.     function stopWatch() { 
  30.         if (watchID) { 
  31.             navigator.accelerometer.clearWatch(watchID); 
  32.             watchID = null
  33.         } 
  34.     } 
  35.      
  36.     // onSuccess: 獲取當前加速度數據的快照 
  37.     function onSuccess(acceleration) { 
  38.         var element = document.getElementById('accelerometer'); 
  39.         element.innerHTML = 'Acceleration X: ' + acceleration.x + '<br  />' + 
  40.                             'Acceleration Y: ' + acceleration.y + '<br  />' + 
  41.                             'Acceleration Z: ' + acceleration.z + '<br  />' + 
  42.                             'Timestamp: '      + acceleration.timestamp + '<br  />'; 
  43.     } 
  44.      
  45.     // onError: 獲取加速度失敗 
  46.     function onError() { 
  47.         alert('onError!'); 
  48.     } 
  49.      
  50. </script> 
  51. </head> 
  52. <body> 
  53.     <div id="accelerometer">Waiting for accelerometer...</div> 
  54.     <button onclick="stopWatch();">Stop Watching</button> 
  55. </body> 
  56. </html> 

Acceleration

包含特定時間點采集到的加速計數據。

屬性

x:在X軸的運動量,[0, 1]范圍(數字類型)

y:在Y軸的運動量,[0, 1]范圍(數字類型)

z:在Z軸的運動量,[0, 1]范圍(數字類型)

timestamp:以毫秒為單位的創建時間戳。(DOMTimeStamp類型)

說明

這個對象是由phoneGap創建和填充,并由Acce這個對象是由PhoneGap創建和填充,并由Accelerometer的方法返回。

支持的平臺

Android

BlackBerry WebWorks (OS 5.0或更高版本)

iPhone

簡單的范例

  1. function onSuccess(acceleration) { 
  2.     alert('Acceleration X: ' + acceleration.x + '\n' + 
  3.     'Acceleration Y: ' + acceleration.y + '\n' + 
  4.     'Acceleration Z: ' + acceleration.z + '\n' + 
  5.     'Timestamp: '      + acceleration.timestamp + '\n'); 
  6.      
  7. function onError() { 
  8.     alert('onError!'); 
  9.      
  10. navigator.accelerometer.getCurrentAcceleration(onSuccess,onError); 

完整的范例

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4. <title>Acceleration Example</title> 
  5.      
  6. <script type="text/javascript" charset="utf-8" src="phonegap.js"></script> 
  7. <script type="text/javascript" charset="utf-8"> 
  8.      
  9.     // 等待加載PhoneGap 
  10.     document.addEventListener("deviceready", onDeviceReady, false); 
  11.      
  12.     // PhoneGap加載完畢 
  13.     function onDeviceReady() { 
  14.         navigator.accelerometer.getCurrentAcceleration(onSuccess, onError); 
  15.     } 
  16.      
  17.     // onSuccess: 獲得加速度數據的快照 
  18.     function onSuccess(acceleration) { 
  19.         alert('Acceleration X: ' + acceleration.x + '\n' + 
  20.         'Acceleration Y: ' + acceleration.y + '\n' + 
  21.         'Acceleration Z: ' + acceleration.z + '\n' + 
  22.         'Timestamp: '      + acceleration.timestamp + '\n'); 
  23.     } 
  24.      
  25.     // onError: 獲取加速度失敗 
  26.     function onError() { 
  27.         alert('onError!'); 
  28.     } 
  29.      
  30. </script> 
  31. </head> 
  32. <body> 
  33.     <h1>Example</h1> 
  34.     <p>getCurrentAcceleration</p> 
  35. </body> 
  36. </html> 

accelerometerSuccess

提供加速度信息的onSuccess回調函數。

  1. function(acceleration) { 
  2.    // 進一步處理 

參數

acceleration: 在某一時刻的加速度(Acacceleration:在某一時刻的加速度。(Acceleration對象類型)

  1. function onSuccess(acceleration) { 
  2.     alert('Acceleration X: ' + acceleration.x + '\n' + 
  3.     'Acceleration Y: ' + acceleration.y + '\n' + 
  4.     'Acceleration Z: ' + acceleration.z + '\n' + 
  5.     'Timestamp: '      + acceleration.timestamp + '\n'); 

accelerometerError

加速度方法的onError回調函數。

  1. function() { 
  2.    // 錯誤處理 

accelerometerOptions

定制檢索加速度計的可選參數。

選項

frequency:多少毫秒獲取一次Acceleration。(數字類型)(默認值:10000)

責任編輯:佚名 來源: PhoneGap中國
相關推薦

2011-12-30 14:16:02

AccelerometPhoneGap AP視頻

2011-12-19 16:26:39

PhoneGap APCapture

2011-12-20 13:32:52

PhoneGap APContacts

2011-12-20 16:09:57

PhoneGap APDevice

2011-12-21 21:56:45

PhoneGap APFile

2011-12-22 09:54:40

PhoneGap APMedia

2011-12-22 10:33:39

PhoneGap APNotificatio

2011-12-22 10:45:32

PhoneGap APStorage

2011-12-20 15:34:55

PhoneGap APConnection

2011-12-22 09:27:36

PhoneGap APGeolocation

2011-12-20 17:15:52

PhoneGap APEvents

2011-12-20 11:20:46

PhoneGap APCompass

2011-12-19 16:09:32

PhoneGap APCamera

2011-12-30 14:05:17

PhoneGap APConnection視頻

2011-12-30 14:13:05

PhoneGap APCamera視頻

2011-12-30 13:59:38

PhoneGap APDevice視頻

2011-12-30 14:09:32

PhoneGap APCompass視頻

2011-12-30 13:47:57

PhoneGap AP視頻Contacts

2011-09-13 13:17:27

PhoneGap AP

2011-07-05 17:29:53

PhoneGapevents
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人精品一区 | 国产伦精品一区二区三区精品视频 | 狠狠夜夜 | 欧美一区成人 | 久久亚洲精品久久国产一区二区 | 国产福利资源 | 亚洲欧美日韩久久久 | 成人在线观看网站 | 99热播精品 | 久久国内精品 | 精品一二区 | 日韩一区二区三区av | 国产91久久久久蜜臀青青天草二 | 三区四区在线观看 | 精品无码久久久久久国产 | 毛片在线免费 | 三a毛片 | 91最新入口| 婷婷久久久久 | 日韩国产精品一区二区三区 | 久久久一区二区 | 毛片免费观看 | 91一区二区三区 | 亚洲免费观看视频网站 | 欧美区在线 | 亚洲国产精品激情在线观看 | 蜜月aⅴ免费一区二区三区 99re在线视频 | 日韩一二区 | 亚洲国产中文字幕 | 91精品国产乱码久久久久久久 | 天天插天天操 | 久久久久久久久久久久久91 | 欧美精品一区三区 | 九九精品影院 | 91精品久久久久久久久99蜜臂 | 91av视频在线观看 | 亚洲最新在线 | 毛片免费视频 | 成人免费视频在线观看 | 天天射色综合 | 亚洲乱码一区二区三区在线观看 |