Cordova 加速计

该插件也称为 设备运动 它用于在三维中跟踪设备运动。

步骤1 – 安装加速计插件

我们将使用 cordova-CLI 安装此插件。键入以下代码到命令提示符窗口。

C:UsersusernameDesktopCordovaProject>cordova plugin add cordova-plugin-device-motion

步骤2 – 添加按钮

接下来,我们需要做的是在 index.html 文件中添加两个按钮。一个用于获取当前加速度,另一个将监视加速度变化。

<button id = "getAcceleration">GET ACCELERATION</button>
<button id = "watchAcceleration">WATCH ACCELERATION</button>

步骤3 – 添加事件监听器

让我们将按钮的事件监听器添加到 index.js 中的 onDeviceReady 函数。

document.getElementById("getAcceleration").addEventListener("click", getAcceleration);
document.getElementById("watchAcceleration").addEventListener("click", watchAcceleration);

步骤4 – 创建函数

我们将创建两个函数。第一个将用于获取当前加速度,第二个将观察加速度,并且每三秒通知一次。我们还添加了由 setTimeout 函数包装的 clearWatch ,以在指定时间范围后停止观看加速。frequency 参数用于每三秒触发一次回调函数。

function getAcceleration(){
   navigator.accelerometer.getCurrentAcceleration(accelerometerSuccess, accelerometerError);

   function accelerometerSuccess(acceleration) {
      alert(Acceleration X:  + acceleration.x + 
 +
         Acceleration Y:  + acceleration.y + 
 +
         Acceleration Z:  + acceleration.z + 
 +
         Timestamp:       + acceleration.timestamp + 
);
   };

   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 + 
 +
         Acceleration Y:  + acceleration.y + 
 +
         Acceleration Z:  + acceleration.z + 
 +
         Timestamp:       + acceleration.timestamp + 
);

      setTimeout(function() {
         navigator.accelerometer.clearWatch(watchID);
      }, 10000);

   };

   function accelerometerError() {
      alert(onError!);
   };
	
}

现在,如果我们按 GET ACCELERATION 按钮,我们将获得当前的加速度值。如果我们按WATCH ACCELERATION,警报将每三秒触发一次。在显示第三个警告后,将调用 clearWatch 函数,并且我们不会再收到任何警报,因为我们将超时设置为10000毫秒。

Cordova Acceleration

作者:andy,如若转载,请注明出处:https://www.web176.com/cordova/9657.html

(0)
打赏 支付宝 支付宝 微信 微信
andy的头像andy
上一篇 2023年2月14日
下一篇 2023年2月14日

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注