mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-09 09:28:31 -04:00
AP_Param: copter with vectors when sending parameters
This commit is contained in:
parent
3624162b18
commit
e873ff1e5f
@ -699,8 +699,7 @@ void AP_Param::notify() const {
|
|||||||
param_header_type = PGM_UINT8(&info->type);
|
param_header_type = PGM_UINT8(&info->type);
|
||||||
}
|
}
|
||||||
|
|
||||||
GCS_MAVLINK::send_parameter_value_all(name, (enum ap_var_type)info->type,
|
send_parameter(name, (enum ap_var_type)param_header_type);
|
||||||
cast_to_float((enum ap_var_type)param_header_type));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -747,8 +746,7 @@ bool AP_Param::save(bool force_save)
|
|||||||
if (scan(&phdr, &ofs)) {
|
if (scan(&phdr, &ofs)) {
|
||||||
// found an existing copy of the variable
|
// found an existing copy of the variable
|
||||||
eeprom_write_check(ap, ofs+sizeof(phdr), type_size((enum ap_var_type)phdr.type));
|
eeprom_write_check(ap, ofs+sizeof(phdr), type_size((enum ap_var_type)phdr.type));
|
||||||
GCS_MAVLINK::send_parameter_value_all(name, (enum ap_var_type)info->type,
|
send_parameter(name, (enum ap_var_type)phdr.type);
|
||||||
cast_to_float((enum ap_var_type)phdr.type));
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
if (ofs == (uint16_t) ~0) {
|
if (ofs == (uint16_t) ~0) {
|
||||||
@ -787,8 +785,8 @@ bool AP_Param::save(bool force_save)
|
|||||||
write_sentinal(ofs + sizeof(phdr) + type_size((enum ap_var_type)phdr.type));
|
write_sentinal(ofs + sizeof(phdr) + type_size((enum ap_var_type)phdr.type));
|
||||||
eeprom_write_check(ap, ofs+sizeof(phdr), type_size((enum ap_var_type)phdr.type));
|
eeprom_write_check(ap, ofs+sizeof(phdr), type_size((enum ap_var_type)phdr.type));
|
||||||
eeprom_write_check(&phdr, ofs, sizeof(phdr));
|
eeprom_write_check(&phdr, ofs, sizeof(phdr));
|
||||||
GCS_MAVLINK::send_parameter_value_all(name, (enum ap_var_type)info->type,
|
|
||||||
cast_to_float((enum ap_var_type)phdr.type));
|
send_parameter(name, (enum ap_var_type)phdr.type);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1447,3 +1445,21 @@ float AP_Param::get_default_value(const float *def_value_ptr)
|
|||||||
return PGM_FLOAT(def_value_ptr);
|
return PGM_FLOAT(def_value_ptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void AP_Param::send_parameter(char *name, enum ap_var_type param_header_type) const
|
||||||
|
{
|
||||||
|
if (param_header_type != AP_PARAM_VECTOR3F) {
|
||||||
|
// nice and simple for scalar types
|
||||||
|
GCS_MAVLINK::send_parameter_value_all(name, param_header_type, cast_to_float(param_header_type));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// for vectors we need to send 3 messages
|
||||||
|
Vector3f *v = (Vector3f *)this;
|
||||||
|
char &name_axis = name[strlen(name)-1];
|
||||||
|
GCS_MAVLINK::send_parameter_value_all(name, AP_PARAM_FLOAT, v->x);
|
||||||
|
name_axis = 'Y';
|
||||||
|
GCS_MAVLINK::send_parameter_value_all(name, AP_PARAM_FLOAT, v->y);
|
||||||
|
name_axis = 'Z';
|
||||||
|
GCS_MAVLINK::send_parameter_value_all(name, AP_PARAM_FLOAT, v->z);
|
||||||
|
}
|
||||||
|
@ -179,6 +179,9 @@ public:
|
|||||||
///
|
///
|
||||||
void notify() const;
|
void notify() const;
|
||||||
|
|
||||||
|
// send a parameter to all GCS instances
|
||||||
|
void send_parameter(char *name, enum ap_var_type param_header_type) const;
|
||||||
|
|
||||||
/// Save the current value of the variable to EEPROM.
|
/// Save the current value of the variable to EEPROM.
|
||||||
///
|
///
|
||||||
/// @param force_save If true then force save even if default
|
/// @param force_save If true then force save even if default
|
||||||
|
Loading…
Reference in New Issue
Block a user