Cordova - İvmeölçer
İvmeölçer eklentisine aynı zamanda device-motion. Cihaz hareketini üç boyutlu olarak takip etmek için kullanılır.
Adım 1 - Accelerometer Eklentisini Kurun
Bu eklentiyi kullanarak kuracağız cordova-CLI. Aşağıdaki kodu şuraya yazın:command prompt pencere.
C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugindevice-motion
Adım 2 - Düğme Ekleme
Bu adımda, iki düğme ekleyeceğiz. index.htmldosya. Biri mevcut ivmeyi elde etmek için kullanılacak, diğeri ise ivme değişikliklerini izleyecek.
<button id = "getAcceleration">GET ACCELERATION</button>
<button id = "watchAcceleration">WATCH ACCELERATION</button>
3. Adım - Etkinlik İşleyicileri Ekleyin
Şimdi düğmelerimiz için olay dinleyicileri ekleyelim. onDeviceReady içeride işlev index.js.
document.getElementById("getAcceleration").addEventListener("click", getAcceleration);
document.getElementById("watchAcceleration").addEventListener(
"click", watchAcceleration);
Adım 4 - Fonksiyon Oluşturma
Şimdi iki fonksiyon oluşturacağız. İlk fonksiyon mevcut ivmeyi elde etmek için kullanılacak ve ikinci fonksiyon hızlanmayı izleyecek ve hızlanma ile ilgili bilgiler her üç saniyede bir tetiklenecektir. Ayrıca ekleyeceğizclearWatch tarafından sarılmış işlev setTimeoutbelirtilen zaman diliminden sonra hızlanmayı izlemeyi durdurma işlevi. frequency parametresi, her üç saniyede bir geri arama işlevini tetiklemek için kullanılır.
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!');
};
}
Şimdi basarsak GET ACCELERATIONdüğmesi, mevcut ivme değerini alacağız. BasarsakWATCH ACCELERATIONdüğmesi, uyarı her üç saniyede bir tetiklenecektir. Üçüncü uyarı gösterildikten sonraclearWatch işlev çağrılacak ve zaman aşımını 10000 milisaniyeye ayarladığımız için artık uyarı almayacağız.