1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-06 17:46:07 +01:00
LibrePilot/ground/src/plugins/uavobjects/attituderaw.h

113 lines
4.0 KiB
C++

/**
******************************************************************************
*
* @file attituderaw.h
* @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2010.
* @see The GNU Public License (GPL) Version 3
* @addtogroup GCSPlugins GCS Plugins
* @{
* @addtogroup UAVObjectsPlugin UAVObjects Plugin
* @{
*
* @note Object definition file: attituderaw.xml.
* This is an automatically generated file.
* DO NOT modify manually.
*
* @brief The UAVUObjects GCS plugin
*****************************************************************************/
/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* for more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef ATTITUDERAW_H
#define ATTITUDERAW_H
#include "uavdataobject.h"
#include "uavobjectmanager.h"
class UAVOBJECTS_EXPORT AttitudeRaw: public UAVDataObject
{
Q_OBJECT
public:
// Field structure
typedef struct {
qint16 magnetometers[3];
quint16 gyros[3];
float gyros_filtered[3];
quint16 gyrotemp[2];
quint16 accels[3];
float accels_filtered[3];
} __attribute__((packed)) DataFields;
// Field information
// Field magnetometers information
/* Array element names for field magnetometers */
typedef enum { MAGNETOMETERS_X=0, MAGNETOMETERS_Y=1, MAGNETOMETERS_Z=2 } magnetometersElem;
/* Number of elements for field magnetometers */
static const quint32 MAGNETOMETERS_NUMELEM = 3;
// Field gyros information
/* Array element names for field gyros */
typedef enum { GYROS_X=0, GYROS_Y=1, GYROS_Z=2 } gyrosElem;
/* Number of elements for field gyros */
static const quint32 GYROS_NUMELEM = 3;
// Field gyros_filtered information
/* Array element names for field gyros_filtered */
typedef enum { GYROS_FILTERED_X=0, GYROS_FILTERED_Y=1, GYROS_FILTERED_Z=2 } gyros_filteredElem;
/* Number of elements for field gyros_filtered */
static const quint32 GYROS_FILTERED_NUMELEM = 3;
// Field gyrotemp information
/* Array element names for field gyrotemp */
typedef enum { GYROTEMP_XY=0, GYROTEMP_Z=1 } gyrotempElem;
/* Number of elements for field gyrotemp */
static const quint32 GYROTEMP_NUMELEM = 2;
// Field accels information
/* Array element names for field accels */
typedef enum { ACCELS_X=0, ACCELS_Y=1, ACCELS_Z=2 } accelsElem;
/* Number of elements for field accels */
static const quint32 ACCELS_NUMELEM = 3;
// Field accels_filtered information
/* Array element names for field accels_filtered */
typedef enum { ACCELS_FILTERED_X=0, ACCELS_FILTERED_Y=1, ACCELS_FILTERED_Z=2 } accels_filteredElem;
/* Number of elements for field accels_filtered */
static const quint32 ACCELS_FILTERED_NUMELEM = 3;
// Constants
static const quint32 OBJID = 1323193976U;
static const QString NAME;
static const bool ISSINGLEINST = 1;
static const bool ISSETTINGS = 0;
static const quint32 NUMBYTES = sizeof(DataFields);
// Functions
AttitudeRaw();
DataFields getData();
void setData(const DataFields& data);
Metadata getDefaultMetadata();
UAVDataObject* clone(quint32 instID);
static AttitudeRaw* GetInstance(UAVObjectManager* objMngr, quint32 instID = 0);
private:
DataFields data;
void setDefaultFieldValues();
};
#endif // ATTITUDERAW_H