blob: efc0fe6d1a0bf86012e17ddca9e680a62b1b5f3f [file] [log] [blame]
Brian Silverman8fce7482020-01-05 13:18:21 -08001/*----------------------------------------------------------------------------*/
Austin Schuh1e69f942020-11-14 15:06:14 -08002/* Copyright (c) 2014-2020 FIRST. All Rights Reserved. */
Brian Silverman8fce7482020-01-05 13:18:21 -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/FRCUsageReporting.h>
12
13#include "frc/WPIErrors.h"
14#include "frc/smartdashboard/SendableBuilder.h"
15#include "frc/smartdashboard/SendableRegistry.h"
16
17using namespace frc;
18
19BuiltInAccelerometer::BuiltInAccelerometer(Range range) {
20 SetRange(range);
21
22 HAL_Report(HALUsageReporting::kResourceType_Accelerometer, 0, 0,
23 "Built-in accelerometer");
24 SendableRegistry::GetInstance().AddLW(this, "BuiltInAccel");
25}
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");
Austin Schuh1e69f942020-11-14 15:06:14 -080046 builder.AddDoubleProperty(
47 "X", [=]() { return GetX(); }, nullptr);
48 builder.AddDoubleProperty(
49 "Y", [=]() { return GetY(); }, nullptr);
50 builder.AddDoubleProperty(
51 "Z", [=]() { return GetZ(); }, nullptr);
Brian Silverman8fce7482020-01-05 13:18:21 -080052}