Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
c-astral-wrapper
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
c-astral-wrapper
Commits
a6619148
Commit
a6619148
authored
Sep 01, 2023
by
Léo-Paul Géneau
👾
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use doReposition and doOverride commands asynchronously
parent
903e38b3
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
26 additions
and
17 deletions
+26
-17
mavsdk_wrapper.cpp
mavsdk_wrapper.cpp
+26
-17
No files found.
mavsdk_wrapper.cpp
View file @
a6619148
...
@@ -157,12 +157,16 @@ static int doReposition(float la, float lo, float radius, float y) {
...
@@ -157,12 +157,16 @@ static int doReposition(float la, float lo, float radius, float y) {
return
doMavlinkCommand
(
command
,
"Entering loiter mode failed"
);
return
doMavlinkCommand
(
command
,
"Entering loiter mode failed"
);
}
}
static
void
doReposition_async
(
float
la
,
float
lo
,
float
radius
,
float
y
)
{
std
::
thread
(
doReposition
,
la
,
lo
,
radius
,
y
).
detach
();
}
static
void
updateProjection
(
double
current_lat
,
double
current_lon
)
{
static
void
updateProjection
(
double
current_lat
,
double
current_lon
)
{
Coordinates
position
{
current_lat
,
current_lon
};
Coordinates
position
{
current_lat
,
current_lon
};
projected_destination
=
getProjectionCoordinates
(
targeted_destination
,
projected_destination
=
getProjectionCoordinates
(
targeted_destination
,
position
);
position
);
return
doReposition
(
doReposition_async
(
(
float
)
projected_destination
.
latitude
,
(
float
)
projected_destination
.
latitude
,
(
float
)
projected_destination
.
longitude
,
(
float
)
projected_destination
.
longitude
,
DEFAULT_RADIUS
,
DEFAULT_RADIUS
,
...
@@ -175,7 +179,7 @@ static long long int getTimestamp() {
...
@@ -175,7 +179,7 @@ static long long int getTimestamp() {
return
std
::
chrono
::
duration_cast
<
std
::
chrono
::
milliseconds
>
(
now
.
time_since_epoch
()).
count
();
return
std
::
chrono
::
duration_cast
<
std
::
chrono
::
milliseconds
>
(
now
.
time_since_epoch
()).
count
();
}
}
int
updateLogAndProjection
(
void
)
{
void
updateLogAndProjection
(
void
)
{
std
::
ostringstream
oss
;
std
::
ostringstream
oss
;
Telemetry
::
Position
position
;
Telemetry
::
Position
position
;
Telemetry
::
FixedwingMetrics
metrics
;
Telemetry
::
FixedwingMetrics
metrics
;
...
@@ -192,11 +196,9 @@ int updateLogAndProjection(void) {
...
@@ -192,11 +196,9 @@ int updateLogAndProjection(void) {
log
(
oss
.
str
());
log
(
oss
.
str
());
if
(
projected_destination
.
latitude
!=
0
||
targeted_destination
.
latitude
!=
0
)
{
if
(
projected_destination
.
latitude
!=
0
||
targeted_destination
.
latitude
!=
0
)
{
return
updateProjection
(
position
.
latitude_deg
,
position
.
longitude_deg
);
updateProjection
(
position
.
latitude_deg
,
position
.
longitude_deg
);
}
}
}
}
return
0
;
}
}
// Connexion management functions
// Connexion management functions
...
@@ -347,30 +349,37 @@ static int setAltitude(float altitude) {
...
@@ -347,30 +349,37 @@ static int setAltitude(float altitude) {
return
doOverride
(
altitude
,
last_override_speed
,
"Setting altitude failed"
);
return
doOverride
(
altitude
,
last_override_speed
,
"Setting altitude failed"
);
}
}
int
loiter
(
double
la
,
double
lo
,
float
a
,
float
radius
)
{
static
void
setAltitude_async
(
float
altitude
)
{
int
result
=
doReposition
((
float
)
la
,
(
float
)
lo
,
radius
,
0
);
std
::
thread
(
setAltitude
,
altitude
).
detach
();
result
|=
setAltitude
(
a
);
}
return
result
;
void
loiter
(
double
la
,
double
lo
,
float
a
,
float
radius
)
{
doReposition_async
((
float
)
la
,
(
float
)
lo
,
radius
,
0
);
setAltitude_async
(
a
);
}
}
int
setAirSpeed
(
float
airspeed
)
{
static
int
setAirSpeed
(
float
airspeed
)
{
last_override_speed
=
airspeed
;
last_override_speed
=
airspeed
;
return
doOverride
(
last_override_altitude
,
airspeed
,
return
doOverride
(
last_override_altitude
,
airspeed
,
"Setting airspeed failed"
);
"Setting airspeed failed"
);
}
}
int
setTargetCoordinates
(
double
la
,
double
lo
,
float
a
)
{
void
setAirSpeed_async
(
float
airspeed
)
{
int
result
;
std
::
thread
(
setAirSpeed
,
airspeed
).
detach
();
if
(
!
mavsdk_started
)
}
return
-
1
;
void
setTargetCoordinates
(
double
la
,
double
lo
,
float
a
)
{
if
(
!
mavsdk_started
)
{
log_error
(
"Mavsdk not started"
);
return
;
}
Telemetry
::
Position
position
=
telemetry
->
position
();
Telemetry
::
Position
position
=
telemetry
->
position
();
targeted_destination
.
latitude
=
la
;
targeted_destination
.
latitude
=
la
;
targeted_destination
.
longitude
=
lo
;
targeted_destination
.
longitude
=
lo
;
result
=
updateProjection
(
position
.
latitude_deg
,
position
.
longitude_deg
);
updateProjection
(
position
.
latitude_deg
,
position
.
longitude_deg
);
result
|=
setAltitude
(
a
);
setAltitude_async
(
a
);
return
result
;
}
}
// Information functions
// Information functions
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment