Subversion Repositories NaviCtrl

Rev

Rev 494 | Rev 496 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
41 ingob 1
#ifndef _WAYPOINTS_H
2
#define _WAYPOINTS_H
3
 
4
#include "ubx.h"
5
 
277 killagreg 6
#define POINT_TYPE_INVALID 255
225 killagreg 7
#define POINT_TYPE_WP   0
8
#define POINT_TYPE_POI  1
9
 
41 ingob 10
typedef struct
11
{
12
        GPS_Pos_t Position;             // the gps position of the waypoint, see ubx.h for details
277 killagreg 13
        s16 Heading;                    // orientation, 0 no action, 1...360 fix heading, neg. = Index to POI in WP List
41 ingob 14
        u8  ToleranceRadius;    // in meters, if the MK is within that range around the target, then the next target is triggered
88 killagreg 15
        u8  HoldTime;                   // in seconds, if the was once in the tolerance area around a WP, this time defines the delay before the next WP is triggered
16
        u8  Event_Flag;                 // future implementation
162 ingob 17
        u8  Index;              // to indentify different waypoints, workaround for bad communications PC <-> NC
225 killagreg 18
        u8  Type;                               // typeof Waypoint
397 holgerb 19
        u8  WP_EventChannelValue;  // Will be transferred to the FC and can be used as Poti value there
491 killagreg 20
        u8      AltitudeRate;           // rate to change the setpoint in steps of 0.1m/s
21
        u8      Speed;                          // rate to change the Position(0 = max) in steps of 0.1m/s
397 holgerb 22
        u8      CamAngle;                       // Camera servo angle in degree (255 -> POI-Automatic)
386 holgerb 23
        u8  Name[4];                // Name of that point (ASCII)
24
    u8  reserve[2];                 // reserve
280 killagreg 25
} __attribute__((packed)) Point_t;
41 ingob 26
 
495 killagreg 27
 
28
#define WPL_STORE_TYPE_REL 0
29
#define WPL_STORE_TYPE_ABS 1
30
 
31
typedef struct
32
{
33
        u8 Index;
34
        u8 Type;                  // 0 = rel, 1 = abs
35
        u8 OverwriteFile;         // 0 = no, 1 = yes
36
        u8 reserved[7];
37
        s8 Name[12];
38
} __attribute__((packed)) WPL_Store_t;
39
 
277 killagreg 40
// Init List, return TRUE on success
280 killagreg 41
u8 PointList_Init(void);
277 killagreg 42
// Clear List, return TRUE on success
280 killagreg 43
u8 PointList_Clear(void);
277 killagreg 44
// Returns number of points in the list
280 killagreg 45
u8 PointList_GetCount(void);
46
// return pointer to point at position
47
Point_t* PointList_GetAt(u8 index);
295 killagreg 48
// set a point in the list at index, returns its index on success, else 0
49
u8 PointList_SetAt(Point_t* pPoint);
277 killagreg 50
// goto the first WP in the list and return pointer to it
280 killagreg 51
Point_t* PointList_WPBegin(void);
277 killagreg 52
// goto the last WP in the list and return pointer to it
280 killagreg 53
Point_t* PointList_WPEnd(void);
277 killagreg 54
// goto next WP in the list and return pointer to it
280 killagreg 55
Point_t* PointList_WPNext(void);
295 killagreg 56
// enables/disables waypoint function
280 killagreg 57
void PointList_WPActive(u8 set);
277 killagreg 58
// returns pointer to actual POI
280 killagreg 59
Point_t* PointList_GetPOI(void);
490 killagreg 60
// save actual point list to SD card
495 killagreg 61
#define WPL_ERROR               0
62
#define WPL_OK                  1
63
#define WPL_FILEEXIST   2
64
u8 PointList_SaveToFile(WPL_Store_t * pWPL_Store);
490 killagreg 65
// load actual point list from SD card
495 killagreg 66
u8 PointList_ReadFromFile(WPL_Store_t * pWPL_Store);
491 killagreg 67
// move actual point list to ref pos., the point in the list marked by RefIndex get the RefPos afterwards
68
u8 PointList_Move(u8 RefIndex, GPS_Pos_t* pRefPos);
41 ingob 69
 
280 killagreg 70
 
41 ingob 71
#endif // _WAYPOINTS_H