2022-12-07 20:19:21 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/AngleConvertor/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/AngleConvertor/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/AngleConvertor/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/AngleConvertor/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/AngleConvertor/actions/workflows/jsoncheck.yml)
|
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/AngleConvertor/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/AngleConvertor.svg?maxAge=3600)](https://github.com/RobTillaart/AngleConvertor/releases)
|
|
|
|
|
|
|
|
|
|
|
|
# AngleConvertor
|
|
|
|
|
|
|
|
Arduino library for converting angles (degrees/radians) to less known formats.
|
|
|
|
|
|
|
|
|
|
|
|
## Description
|
|
|
|
|
|
|
|
AngleConvertor is an Arduino class to convert an angle from and to less known formats.
|
|
|
|
|
|
|
|
|
|
|
|
#### Formats
|
|
|
|
|
|
|
|
|
|
|
|
| name | full circle |
|
|
|
|
|:----------------|--------------:|
|
|
|
|
| Degrees | 360 |
|
|
|
|
| Radians | 2 PI |
|
|
|
|
| Gradians | 400 |
|
|
|
|
| AngularMil | 6400 |
|
|
|
|
| BinaryRadians | 256 |
|
|
|
|
| CentiTurn | 100 |
|
|
|
|
| DiameterPart | 120 |
|
|
|
|
| Hexacontade | 60 |
|
|
|
|
| HourAngle | 24 |
|
|
|
|
| MilliTurn | 1000 |
|
|
|
|
| MinuteTime | 1440 |
|
|
|
|
| Octant | 8 |
|
|
|
|
| Pechus | 180 |
|
|
|
|
| Points | 32 |
|
|
|
|
| Quadrant | 4 |
|
|
|
|
| QuarterPoint | 128 |
|
|
|
|
| SecondsTime | 86400 |
|
|
|
|
| Sextant | 6 |
|
|
|
|
| Sign | 12 |
|
|
|
|
| Turn | 1 |
|
|
|
|
|
|
|
|
|
2023-01-31 16:28:11 +01:00
|
|
|
#### Related
|
|
|
|
|
|
|
|
- https://github.com/RobTillaart/AngleConvertor
|
2022-12-07 20:19:21 +01:00
|
|
|
- https://github.com/RobTillaart/AverageAngle
|
|
|
|
- https://github.com/RobTillaart/Angle
|
|
|
|
- https://github.com/RobTillaart/runningAngle
|
|
|
|
|
|
|
|
|
|
|
|
## Interface
|
|
|
|
|
2023-01-31 16:28:11 +01:00
|
|
|
```cpp
|
|
|
|
#include "AngleConvertor.h"
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2022-12-07 20:19:21 +01:00
|
|
|
#### Constructor
|
|
|
|
|
|
|
|
- **AngleConvertor()** create an AngleConvertor, default value is zero.
|
|
|
|
|
|
|
|
|
2023-01-31 16:28:11 +01:00
|
|
|
#### Setters
|
2022-12-07 20:19:21 +01:00
|
|
|
|
|
|
|
- **void setDegrees(float value = 0)**
|
|
|
|
- **void setRadians(float value = 0)**
|
|
|
|
- **void setGradians(float value = 0)**
|
|
|
|
- **void setAngularMil(float value = 0)**
|
|
|
|
- **void setBinaryRadians(float value = 0)**
|
|
|
|
- **void setCentiTurn(float value = 0)**
|
|
|
|
- **void setDiameterPart(float value = 0)**
|
|
|
|
- **void setHexacontade(float value = 0)**
|
|
|
|
- **void setHourAngle(float value = 0)**
|
|
|
|
- **void setMilliTurn(float value = 0)**
|
|
|
|
- **void setMinuteTime(float value = 0)**
|
|
|
|
- **void setOctant(float value = 0)**
|
|
|
|
- **void setPechus(float value = 0)**
|
|
|
|
- **void setPoints(float value = 0)**
|
|
|
|
- **void setQuadrant(float value = 0)**
|
|
|
|
- **void setQuarterPoint(float value = 0)**
|
|
|
|
- **void setSecondsTime(float value = 0)**
|
|
|
|
- **void setSextant(float value = 0)**
|
|
|
|
- **void setSign(float value = 0)**
|
|
|
|
- **void setTurn(float value = 0)**
|
|
|
|
|
|
|
|
|
2023-01-31 16:28:11 +01:00
|
|
|
#### Getters
|
2022-12-07 20:19:21 +01:00
|
|
|
|
|
|
|
- **float getDegrees()**
|
|
|
|
- **float getRadians()**
|
|
|
|
- **float getGradians()**
|
|
|
|
- **float getAngularMil()**
|
|
|
|
- **float getBinaryRadians()**
|
|
|
|
- **float getCentiTurn()**
|
|
|
|
- **float getDiameterPart()**
|
|
|
|
- **float getHexacontade()**
|
|
|
|
- **float getHourAngle()**
|
|
|
|
- **float getMilliTurn()**
|
|
|
|
- **float getMinuteTime()**
|
|
|
|
- **float getOctant()**
|
|
|
|
- **float getPechus()**
|
|
|
|
- **float getPoints()**
|
|
|
|
- **float getQuadrant()**
|
|
|
|
- **float getQuarterPoint()**
|
|
|
|
- **float getSecondsTime()**
|
|
|
|
- **float getSextant()**
|
|
|
|
- **float getSign()**
|
|
|
|
- **float getTurn()**
|
|
|
|
|
2023-01-31 16:28:11 +01:00
|
|
|
#### WindRose
|
|
|
|
|
|
|
|
|
|
|
|
From: https://forum.arduino.cc/t/function-optimization-wind-direction-open-for-ideas/92493/10
|
|
|
|
|
|
|
|
Converts an angle in degrees to a char array like "WSW".
|
|
|
|
0 and 360 degrees is considered North.
|
|
|
|
|
|
|
|
- **char \* windrose()** converter version.
|
|
|
|
- **char \* windrose(float degrees)** stand alone version.
|
|
|
|
degrees should be between 0 and 360, as function does no normalization.
|
|
|
|
|
2022-12-07 20:19:21 +01:00
|
|
|
|
|
|
|
## Operation
|
|
|
|
|
|
|
|
See examples.
|
|
|
|
|
|
|
|
|
|
|
|
## Future
|
|
|
|
|
2023-01-31 16:28:11 +01:00
|
|
|
#### Must
|
|
|
|
|
2022-12-07 20:19:21 +01:00
|
|
|
- improve documentation
|
|
|
|
|
2023-01-31 16:28:11 +01:00
|
|
|
#### Should
|
2022-12-07 20:19:21 +01:00
|
|
|
|
|
|
|
|
2023-01-31 16:28:11 +01:00
|
|
|
#### Could
|
|
|
|
|
2022-12-07 20:19:21 +01:00
|
|
|
- add dedicated functions == faster (on request only).
|
|
|
|
- add more conversions
|
|
|
|
- integrate with **Angle class** ?
|
|
|
|
- printing can be a lot of work
|
|
|
|
|