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 
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:
69 
70  int _vehicle_roi_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  */
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 */
static int timeout_ms
Definition: common.h:45
class InputBase Base class for all driver input classes
Definition: input.h:52
This defines the common API between an input and an output of the vmount driver.
Definition: common.h:55