Cordova - มาตรความเร่ง
ปลั๊กอิน Accelerometer เรียกอีกอย่างว่า device-motion. ใช้เพื่อติดตามการเคลื่อนไหวของอุปกรณ์ในรูปแบบสามมิติ
ขั้นตอนที่ 1 - ติดตั้ง Accelerometer Plugin
เราจะติดตั้งปลั๊กอินนี้โดยใช้ cordova-CLI. พิมพ์รหัสต่อไปนี้ในไฟล์command prompt หน้าต่าง.
C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugindevice-motion
ขั้นตอนที่ 2 - เพิ่มปุ่ม
ในขั้นตอนนี้เราจะเพิ่มปุ่มสองปุ่มในไฟล์ index.htmlไฟล์. หนึ่งจะถูกใช้เพื่อรับความเร่งปัจจุบันและอีกอันจะคอยดูการเปลี่ยนแปลงของความเร่ง
<button id = "getAcceleration">GET ACCELERATION</button>
<button id = "watchAcceleration">WATCH ACCELERATION</button>
ขั้นตอนที่ 3 - เพิ่มผู้ฟังเหตุการณ์
ตอนนี้ให้เราเพิ่มผู้ฟังเหตุการณ์สำหรับปุ่มของเรา onDeviceReady ฟังก์ชั่นภายใน index.js.
document.getElementById("getAcceleration").addEventListener("click", getAcceleration);
document.getElementById("watchAcceleration").addEventListener(
"click", watchAcceleration);
ขั้นตอนที่ 4 - การสร้างฟังก์ชัน
ตอนนี้เราจะสร้างสองฟังก์ชัน ฟังก์ชันแรกจะถูกใช้เพื่อรับการเร่งความเร็วปัจจุบันและฟังก์ชันที่สองจะเฝ้าดูการเร่งความเร็วและข้อมูลเกี่ยวกับการเร่งความเร็วจะถูกเรียกทุกๆสามวินาที เราจะเพิ่มไฟล์clearWatch ฟังก์ชันห่อด้วย setTimeoutฟังก์ชั่นหยุดดูการเร่งความเร็วหลังจากกรอบเวลาที่กำหนด frequency พารามิเตอร์ถูกใช้เพื่อทริกเกอร์ฟังก์ชันเรียกกลับทุกสามวินาที
function getAcceleration() {
navigator.accelerometer.getCurrentAcceleration(
accelerometerSuccess, accelerometerError);
function accelerometerSuccess(acceleration) {
alert('Acceleration X: ' + acceleration.x + '\n' +
'Acceleration Y: ' + acceleration.y + '\n' +
'Acceleration Z: ' + acceleration.z + '\n' +
'Timestamp: ' + acceleration.timestamp + '\n');
};
function accelerometerError() {
alert('onError!');
};
}
function watchAcceleration() {
var accelerometerOptions = {
frequency: 3000
}
var watchID = navigator.accelerometer.watchAcceleration(
accelerometerSuccess, accelerometerError, accelerometerOptions);
function accelerometerSuccess(acceleration) {
alert('Acceleration X: ' + acceleration.x + '\n' +
'Acceleration Y: ' + acceleration.y + '\n' +
'Acceleration Z: ' + acceleration.z + '\n' +
'Timestamp: ' + acceleration.timestamp + '\n');
setTimeout(function() {
navigator.accelerometer.clearWatch(watchID);
}, 10000);
};
function accelerometerError() {
alert('onError!');
};
}
ตอนนี้ถ้าเรากด GET ACCELERATIONเราจะได้รับค่าความเร่งปัจจุบัน หากเรากดปุ่มWATCH ACCELERATIONปุ่มการแจ้งเตือนจะถูกเรียกทุกสามวินาที หลังจากการแจ้งเตือนครั้งที่สามจะแสดงไฟล์clearWatch ฟังก์ชันจะถูกเรียกและเราจะไม่ได้รับการแจ้งเตือนอีกต่อไปเนื่องจากเราตั้งค่าการหมดเวลาไว้ที่ 10,000 มิลลิวินาที