PX4 Firmware
PX4 Autopilot Software http://px4.io
input_mavlink.h
Go to the documentation of this file.
1
/****************************************************************************
2
*
3
* Copyright (c) 2016-2017 PX4 Development Team. All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions
7
* are met:
8
*
9
* 1. Redistributions of source code must retain the above copyright
10
* notice, this list of conditions and the following disclaimer.
11
* 2. Redistributions in binary form must reproduce the above copyright
12
* notice, this list of conditions and the following disclaimer in
13
* the documentation and/or other materials provided with the
14
* distribution.
15
* 3. Neither the name PX4 nor the names of its contributors may be
16
* used to endorse or promote products derived from this software
17
* without specific prior written permission.
18
*
19
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
22
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
24
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
26
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
27
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
29
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30
* POSSIBILITY OF SUCH DAMAGE.
31
*
32
****************************************************************************/
33
34
/**
35
* @file input_mavlink.h
36
* @author Beat Küng <beat-kueng@gmx.net>
37
*
38
*/
39
40
#pragma once
41
42
#include "
input.h
"
43
#include "
input_rc.h
"
44
#include <cstdint>
45
46
#include <
uORB/topics/vehicle_command.h
>
47
#include <
uORB/topics/vehicle_roi.h
>
48
49
namespace
vmount
50
{
51
/**
52
** class InputMavlinkROI
53
** Input based on the vehicle_roi topic
54
*/
55
class
InputMavlinkROI
:
public
InputBase
56
{
57
public
:
58
InputMavlinkROI
() =
default
;
59
virtual
~InputMavlinkROI
();
60
61
virtual
void
print_status
();
62
63
protected
:
64
virtual
int
update_impl
(
unsigned
int
timeout_ms
,
ControlData
**control_data,
bool
already_active);
65
virtual
int
initialize
();
66
67
private
:
68
void
_read_control_data_from_position_setpoint_sub
();
69
70
int
_vehicle_roi_sub
= -1;
71
int
_position_setpoint_triplet_sub
= -1;
72
uint8_t
_cur_roi_mode
= vehicle_roi_s::ROI_NONE;
73
};
74
75
76
/**
77
** class InputMavlinkCmdMount
78
** Input based on the VEHICLE_CMD_DO_MOUNT_CONTROL mavlink command
79
*/
80
class
InputMavlinkCmdMount
:
public
InputBase
81
{
82
public
:
83
InputMavlinkCmdMount
(
bool
stabilize);
84
virtual
~
InputMavlinkCmdMount
();
85
86
virtual
void
print_status
();
87
88
protected
:
89
virtual
int
update_impl
(
unsigned
int
timeout_ms
,
ControlData
**control_data,
bool
already_active);
90
virtual
int
initialize
();
91
92
private
:
93
void
_ack_vehicle_command(
vehicle_command_s
*cmd);
94
95
int
_vehicle_command_sub = -1;
96
bool
_stabilize[3] = {
false
,
false
,
false
};
97
98
int32_t _mav_sys_id{1};
///< our mavlink system id
99
int32_t _mav_comp_id{1};
///< our mavlink component id
100
};
101
102
103
}
/* namespace vmount */
input.h
timeout_ms
static int timeout_ms
Definition:
hott_telemetry.cpp:73
vmount::InputMavlinkROI
class InputMavlinkROI Input based on the vehicle_roi topic
Definition:
input_mavlink.h:55
vmount::InputMavlinkROI::_cur_roi_mode
uint8_t _cur_roi_mode
Definition:
input_mavlink.h:72
vmount
Definition:
common.h:45
vmount::InputMavlinkROI::_position_setpoint_triplet_sub
int _position_setpoint_triplet_sub
Definition:
input_mavlink.h:71
vmount::InputMavlinkROI::initialize
virtual int initialize()
Definition:
input_mavlink.cpp:67
vmount::InputMavlinkCmdMount
class InputMavlinkCmdMount Input based on the VEHICLE_CMD_DO_MOUNT_CONTROL mavlink command ...
Definition:
input_mavlink.h:80
vmount::InputMavlinkROI::update_impl
virtual int update_impl(unsigned int timeout_ms, ControlData **control_data, bool already_active)
Definition:
input_mavlink.cpp:84
input_rc.h
vmount::InputMavlinkROI::print_status
virtual void print_status()
report status to stdout
Definition:
input_mavlink.cpp:172
vmount::InputMavlinkROI::InputMavlinkROI
InputMavlinkROI()=default
vmount::InputMavlinkROI::_vehicle_roi_sub
int _vehicle_roi_sub
Definition:
input_mavlink.h:70
vmount::InputBase
class InputBase Base class for all driver input classes
Definition:
input.h:52
vmount::InputMavlinkROI::_read_control_data_from_position_setpoint_sub
void _read_control_data_from_position_setpoint_sub()
Definition:
input_mavlink.cpp:163
vmount::ControlData
This defines the common API between an input and an output of the vmount driver.
Definition:
common.h:55
vmount::InputMavlinkROI::~InputMavlinkROI
virtual ~InputMavlinkROI()
Definition:
input_mavlink.cpp:56
vehicle_roi.h
vehicle_command.h
vehicle_command_s
Definition:
vehicle_command.h:147
src
modules
vmount
input_mavlink.h
Generated by
1.8.13