blob: 71c8e89ebde59dc99c8b9d99e40a303811b658a9 [file] [log] [blame]
Brian Silverman41cdd3e2019-01-19 19:48:58 -08001/*----------------------------------------------------------------------------*/
James Kuszmaul4f3ad3c2019-12-01 16:35:21 -08002/* Copyright (c) 2014-2019 FIRST. All Rights Reserved. */
Brian Silverman41cdd3e2019-01-19 19:48:58 -08003/* Open Source Software - may be modified and shared by FRC teams. The code */
4/* must be accompanied by the FIRST BSD license file in the root directory of */
5/* the project. */
6/*----------------------------------------------------------------------------*/
7
8#include "frc/BuiltInAccelerometer.h"
9
10#include <hal/Accelerometer.h>
11#include <hal/HAL.h>
12
13#include "frc/WPIErrors.h"
14#include "frc/smartdashboard/SendableBuilder.h"
James Kuszmaul4f3ad3c2019-12-01 16:35:21 -080015#include "frc/smartdashboard/SendableRegistry.h"
Brian Silverman41cdd3e2019-01-19 19:48:58 -080016
17using namespace frc;
18
19BuiltInAccelerometer::BuiltInAccelerometer(Range range) {
20 SetRange(range);
21
22 HAL_Report(HALUsageReporting::kResourceType_Accelerometer, 0, 0,
23 "Built-in accelerometer");
James Kuszmaul4f3ad3c2019-12-01 16:35:21 -080024 SendableRegistry::GetInstance().AddLW(this, "BuiltInAccel");
Brian Silverman41cdd3e2019-01-19 19:48:58 -080025}
26
27void BuiltInAccelerometer::SetRange(Range range) {
28 if (range == kRange_16G) {
29 wpi_setWPIErrorWithContext(
30 ParameterOutOfRange, "16G range not supported (use k2G, k4G, or k8G)");
31 }
32
33 HAL_SetAccelerometerActive(false);
34 HAL_SetAccelerometerRange((HAL_AccelerometerRange)range);
35 HAL_SetAccelerometerActive(true);
36}
37
38double BuiltInAccelerometer::GetX() { return HAL_GetAccelerometerX(); }
39
40double BuiltInAccelerometer::GetY() { return HAL_GetAccelerometerY(); }
41
42double BuiltInAccelerometer::GetZ() { return HAL_GetAccelerometerZ(); }
43
44void BuiltInAccelerometer::InitSendable(SendableBuilder& builder) {
45 builder.SetSmartDashboardType("3AxisAccelerometer");
46 builder.AddDoubleProperty("X", [=]() { return GetX(); }, nullptr);
47 builder.AddDoubleProperty("Y", [=]() { return GetY(); }, nullptr);
48 builder.AddDoubleProperty("Z", [=]() { return GetZ(); }, nullptr);
49}