C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-device-orientation
如果你有學習我們前面教程,你可能會注意到,這個插件它類似于加速度插件。我們在本教程中使用的是同一個概念。讓我們在 index.html 文件中創(chuàng)建兩個按鈕
<button id = "getOrientation">GET ORIENTATION</button> <button id = "watchOrientation">WATCH ORIENTATION</button>
document.getElementById("getOrientation").addEventListener("click", getOrientation);
document.getElementById("watchOrientation").addEventListener("click", watchOrientation);
我們將創(chuàng)建兩個函數,一個來獲取當前加速度,另外一個用來監(jiān)視方向的變化??梢钥吹皆俅问褂妙l率選項,因為我們希望每三秒鐘觀察其變化。
function getOrientation(){
navigator.compass.getCurrentHeading(compassSuccess, compassError);
function compassSuccess(heading) {
alert('Heading: ' + heading.magneticHeading);
};
function compassError(error) {
alert('CompassError: ' + error.code);
};
}
function watchOrientation(){
var compassOptions = {
frequency: 3000
}
var watchID = navigator.compass.watchHeading(compassSuccess, compassError, compassOptions);
function compassSuccess(heading) {
alert('Heading: ' + heading.magneticHeading);
setTimeout(function() {
navigator.compass.clearWatch(watchID);
}, 10000);
};
function compassError(error) {
alert('CompassError: ' + error.code);
};
}
由于指南針插件幾乎與加速度插件是一樣的,這次我們告訴你錯誤代碼。一些設備不具有指南針工作所需要的磁傳感器。如果您的設備沒有,會得到下面的錯誤。