From 31c0ec6191af1a9d8f491876942a404d4f85468a Mon Sep 17 00:00:00 2001 From: Jakob Stendahl Date: Wed, 24 Feb 2021 11:45:14 +0100 Subject: :truck: Move header files to inc folder --- CMakeLists.txt | 3 +- inc/HoverBitController.h | 75 +++++++++++++++++++++++++++++++++++++++++++++ inc/Screen.h | 73 +++++++++++++++++++++++++++++++++++++++++++ source/HoverBitController.h | 75 --------------------------------------------- source/Screen.h | 73 ------------------------------------------- 5 files changed, 150 insertions(+), 149 deletions(-) create mode 100644 inc/HoverBitController.h create mode 100644 inc/Screen.h delete mode 100644 source/HoverBitController.h delete mode 100644 source/Screen.h diff --git a/CMakeLists.txt b/CMakeLists.txt index ac32e4b..879568c 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -43,6 +43,7 @@ sbeParseJson(codal codal_json) set(CODAL_APP_OUTPUT_DIR ".") set(CODAL_APP_SOURCE_DIR "source") +set(CODAL_APP_INCLUDE_DIR "inc") if("${codal.application}" STRGREATER "") set(CODAL_APP_SOURCE_DIR "${codal.application}") @@ -231,7 +232,7 @@ if("${device.libraries}" STRGREATER "") endif() #finally, find sources and includes of the application, and create a target. -RECURSIVE_FIND_DIR(INCLUDE_DIRS "./inc" "${PROJECT_SOURCE_DIR}/${CODAL_APP_SOURCE_DIR}" "*.h") +RECURSIVE_FIND_DIR(INCLUDE_DIRS "${PROJECT_SOURCE_DIR}/${CODAL_APP_INCLUDE_DIR}" "*.h") # *.c?? only catches .cpp, not .c, so let's be precise RECURSIVE_FIND_FILE(SOURCE_FILES "${PROJECT_SOURCE_DIR}/${CODAL_APP_SOURCE_DIR}" "*.cpp") diff --git a/inc/HoverBitController.h b/inc/HoverBitController.h new file mode 100644 index 0000000..0c2960a --- /dev/null +++ b/inc/HoverBitController.h @@ -0,0 +1,75 @@ +/* +The MIT License (MIT) + +Copyright (c) 2016 British Broadcasting Corporation. +This software is provided by Lancaster University by arrangement with the BBC. + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and associated documentation files (the "Software"), +to deal in the Software without restriction, including without limitation +the rights to use, copy, modify, merge, publish, distribute, sublicense, +and/or sell copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +DEALINGS IN THE SOFTWARE. +*/ +#ifndef HOVERBITCONTROLLER_H_ +#define HOVERBITCONTROLLER_H_ + +#include + +#define BATTERY_LOW_LIMIT 3500 +#define FSAFE_TLIM_THROTTLE 1000 // When to cut the throttle +#define FSAFE_TLIM_ARM 5000 // When to disarm + +/** + * This class can be used to interface with a AirBit card for controlling a HOVER:BIT kit. + * + * A lot of the features of the airbit is ignored here and made easy to understand if all + * you want to do is use it for a hoverbit. + */ +class HoverBitController { + private: + MicroBit* uBit; + + int buzzer; + int servo_1; + int arm; + int roll; + int pitch; + int yaw; + int throttle; + unsigned long lastReceiveTime; + + bool mainController; + bool batteryEmpty; + int batteryMilliVolt; + float batteryFactor; + + bool failSafe(void); + void AirBit(int Pitch,int Arm,int Roll,int Throttle,int Yaw,int Aux1,int Aux2); + + public: + void init(MicroBit* _uBit); + unsigned int GetBatteryVoltage(void); + void HoverControl(); + + int Throttle(); + void Throttle(int _throttle); + int Rudder(); + void Rudder(int _rudder); + bool Arm(); + void Arm(bool _arm); + bool BatteryEmpty(); +}; + +#endif // HOVERBITCONTROLLER_H_ diff --git a/inc/Screen.h b/inc/Screen.h new file mode 100644 index 0000000..b60ba2b --- /dev/null +++ b/inc/Screen.h @@ -0,0 +1,73 @@ +/* +The MIT License (MIT) + +Copyright (c) 2016 British Broadcasting Corporation. +This software is provided by Lancaster University by arrangement with the BBC. + +Permission is hereby granted, free of charge, to any person obtaining a +copy of this software and associated documentation files (the "Software"), +to deal in the Software without restriction, including without limitation +the rights to use, copy, modify, merge, publish, distribute, sublicense, +and/or sell copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +DEALINGS IN THE SOFTWARE. +*/ +#ifndef SCREEN_H_ +#define SCREEN_H_ + +#include + +enum DisplayMainScreenMode { GRAPHS, BATTERY, OFF }; + +const char* const strBattDead = "\ + 000,255,255,255,000\n\ + 255,000,255,000,255\n\ + 255,255,255,255,255\n\ + 000,255,000,255,000\n\ + 000,255,000,255,000\n"; +const char* const strBattLow = "\ + 000,000,255,000,000\n\ + 000,255,255,255,000\n\ + 000,255,000,255,000\n\ + 000,255,000,255,000\n\ + 000,255,255,255,000\n"; +static const char* const strBattLevel[] = { + "\ + 000,000,255,000,000\n\ + 000,255,000,255,000\n\ + 000,255,000,255,000\n\ + 000,255,000,255,000\n\ + 000,255,255,255,000\n", + "\ + 000,000,255,000,000\n\ + 000,255,000,255,000\n\ + 000,255,000,255,000\n\ + 000,255,255,255,000\n\ + 000,255,255,255,000\n", + "\ + 000,000,255,000,000\n\ + 000,255,000,255,000\n\ + 000,255,255,255,000\n\ + 000,255,255,255,000\n\ + 000,255,255,255,000\n", + "\ + 000,000,255,000,000\n\ + 000,255,255,255,000\n\ + 000,255,255,255,000\n\ + 000,255,255,255,000\n\ + 000,255,255,255,000\n" +}; + +void plotYLine(MicroBit *uBit, int y1, int y2, int x); + +#endif // SCREEN_H_ diff --git a/source/HoverBitController.h b/source/HoverBitController.h deleted file mode 100644 index 0c2960a..0000000 --- a/source/HoverBitController.h +++ /dev/null @@ -1,75 +0,0 @@ -/* -The MIT License (MIT) - -Copyright (c) 2016 British Broadcasting Corporation. -This software is provided by Lancaster University by arrangement with the BBC. - -Permission is hereby granted, free of charge, to any person obtaining a -copy of this software and associated documentation files (the "Software"), -to deal in the Software without restriction, including without limitation -the rights to use, copy, modify, merge, publish, distribute, sublicense, -and/or sell copies of the Software, and to permit persons to whom the -Software is furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING -FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER -DEALINGS IN THE SOFTWARE. -*/ -#ifndef HOVERBITCONTROLLER_H_ -#define HOVERBITCONTROLLER_H_ - -#include - -#define BATTERY_LOW_LIMIT 3500 -#define FSAFE_TLIM_THROTTLE 1000 // When to cut the throttle -#define FSAFE_TLIM_ARM 5000 // When to disarm - -/** - * This class can be used to interface with a AirBit card for controlling a HOVER:BIT kit. - * - * A lot of the features of the airbit is ignored here and made easy to understand if all - * you want to do is use it for a hoverbit. - */ -class HoverBitController { - private: - MicroBit* uBit; - - int buzzer; - int servo_1; - int arm; - int roll; - int pitch; - int yaw; - int throttle; - unsigned long lastReceiveTime; - - bool mainController; - bool batteryEmpty; - int batteryMilliVolt; - float batteryFactor; - - bool failSafe(void); - void AirBit(int Pitch,int Arm,int Roll,int Throttle,int Yaw,int Aux1,int Aux2); - - public: - void init(MicroBit* _uBit); - unsigned int GetBatteryVoltage(void); - void HoverControl(); - - int Throttle(); - void Throttle(int _throttle); - int Rudder(); - void Rudder(int _rudder); - bool Arm(); - void Arm(bool _arm); - bool BatteryEmpty(); -}; - -#endif // HOVERBITCONTROLLER_H_ diff --git a/source/Screen.h b/source/Screen.h deleted file mode 100644 index b60ba2b..0000000 --- a/source/Screen.h +++ /dev/null @@ -1,73 +0,0 @@ -/* -The MIT License (MIT) - -Copyright (c) 2016 British Broadcasting Corporation. -This software is provided by Lancaster University by arrangement with the BBC. - -Permission is hereby granted, free of charge, to any person obtaining a -copy of this software and associated documentation files (the "Software"), -to deal in the Software without restriction, including without limitation -the rights to use, copy, modify, merge, publish, distribute, sublicense, -and/or sell copies of the Software, and to permit persons to whom the -Software is furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING -FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER -DEALINGS IN THE SOFTWARE. -*/ -#ifndef SCREEN_H_ -#define SCREEN_H_ - -#include - -enum DisplayMainScreenMode { GRAPHS, BATTERY, OFF }; - -const char* const strBattDead = "\ - 000,255,255,255,000\n\ - 255,000,255,000,255\n\ - 255,255,255,255,255\n\ - 000,255,000,255,000\n\ - 000,255,000,255,000\n"; -const char* const strBattLow = "\ - 000,000,255,000,000\n\ - 000,255,255,255,000\n\ - 000,255,000,255,000\n\ - 000,255,000,255,000\n\ - 000,255,255,255,000\n"; -static const char* const strBattLevel[] = { - "\ - 000,000,255,000,000\n\ - 000,255,000,255,000\n\ - 000,255,000,255,000\n\ - 000,255,000,255,000\n\ - 000,255,255,255,000\n", - "\ - 000,000,255,000,000\n\ - 000,255,000,255,000\n\ - 000,255,000,255,000\n\ - 000,255,255,255,000\n\ - 000,255,255,255,000\n", - "\ - 000,000,255,000,000\n\ - 000,255,000,255,000\n\ - 000,255,255,255,000\n\ - 000,255,255,255,000\n\ - 000,255,255,255,000\n", - "\ - 000,000,255,000,000\n\ - 000,255,255,255,000\n\ - 000,255,255,255,000\n\ - 000,255,255,255,000\n\ - 000,255,255,255,000\n" -}; - -void plotYLine(MicroBit *uBit, int y1, int y2, int x); - -#endif // SCREEN_H_ -- cgit v1.2.3