blob: 8b80bcacfc32504558bde35b957f8ddb38ace56a [file] [log] [blame]
Brian Silvermanf7f267a2017-02-04 16:16:08 -08001/*----------------------------------------------------------------------------*/
2/* Copyright (c) FIRST 2014-2017. All Rights Reserved. */
3/* 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 "BuiltInAccelerometer.h"
9
10#include "HAL/Accelerometer.h"
11#include "HAL/HAL.h"
12#include "LiveWindow/LiveWindow.h"
13#include "WPIErrors.h"
14
15using namespace frc;
16
17/**
18 * Constructor.
19 *
20 * @param range The range the accelerometer will measure
21 */
22BuiltInAccelerometer::BuiltInAccelerometer(Range range) {
23 SetRange(range);
24
25 HAL_Report(HALUsageReporting::kResourceType_Accelerometer, 0, 0,
26 "Built-in accelerometer");
27 LiveWindow::GetInstance()->AddSensor((std::string) "BuiltInAccel", 0, this);
28}
29
30void BuiltInAccelerometer::SetRange(Range range) {
31 if (range == kRange_16G) {
32 wpi_setWPIErrorWithContext(
33 ParameterOutOfRange, "16G range not supported (use k2G, k4G, or k8G)");
34 }
35
36 HAL_SetAccelerometerActive(false);
37 HAL_SetAccelerometerRange((HAL_AccelerometerRange)range);
38 HAL_SetAccelerometerActive(true);
39}
40
41/**
42 * @return The acceleration of the roboRIO along the X axis in g-forces
43 */
44double BuiltInAccelerometer::GetX() { return HAL_GetAccelerometerX(); }
45
46/**
47 * @return The acceleration of the roboRIO along the Y axis in g-forces
48 */
49double BuiltInAccelerometer::GetY() { return HAL_GetAccelerometerY(); }
50
51/**
52 * @return The acceleration of the roboRIO along the Z axis in g-forces
53 */
54double BuiltInAccelerometer::GetZ() { return HAL_GetAccelerometerZ(); }
55
56std::string BuiltInAccelerometer::GetSmartDashboardType() const {
57 return "3AxisAccelerometer";
58}
59
60void BuiltInAccelerometer::InitTable(std::shared_ptr<ITable> subtable) {
61 m_table = subtable;
62 UpdateTable();
63}
64
65void BuiltInAccelerometer::UpdateTable() {
66 if (m_table != nullptr) {
67 m_table->PutNumber("X", GetX());
68 m_table->PutNumber("Y", GetY());
69 m_table->PutNumber("Z", GetZ());
70 }
71}
72
73std::shared_ptr<ITable> BuiltInAccelerometer::GetTable() const {
74 return m_table;
75}