fix: 分段pid的bug修复
This commit is contained in:
@@ -2,9 +2,9 @@
|
|||||||
#include "jj_motion.h"
|
#include "jj_motion.h"
|
||||||
#include "by_fan_control.h"
|
#include "by_fan_control.h"
|
||||||
bool bt_rx_flag = false;
|
bool bt_rx_flag = false;
|
||||||
uint8 bt_buffer; // 接收字符存入
|
uint8_t bt_buffer; // 接收字符存入
|
||||||
uint32_t bt_run_flag = 0;
|
uint8_t bt_run_flag = 0;
|
||||||
uint8_t bt_fly_flag = 0;
|
uint8_t bt_fly_flag = 0;
|
||||||
uint32_t bt_run = 0;
|
uint32_t bt_run = 0;
|
||||||
uint32_t bt_fly = 500;
|
uint32_t bt_fly = 500;
|
||||||
enum bt_order {
|
enum bt_order {
|
||||||
|
|||||||
@@ -10,8 +10,8 @@
|
|||||||
#define BT_UART_RX_PIN UART8_MAP0_RX_C5
|
#define BT_UART_RX_PIN UART8_MAP0_RX_C5
|
||||||
|
|
||||||
extern bool bt_rx_flag;
|
extern bool bt_rx_flag;
|
||||||
extern uint8 bt_buffer; // 接收字符存入
|
extern uint8_t bt_buffer; // 接收字符存入
|
||||||
extern uint32_t bt_run_flag;
|
extern uint8_t bt_run_flag;
|
||||||
extern uint8_t bt_fly_flag;
|
extern uint8_t bt_fly_flag;
|
||||||
extern uint32_t bt_run;
|
extern uint32_t bt_run;
|
||||||
extern uint32_t bt_fly;
|
extern uint32_t bt_fly;
|
||||||
|
|||||||
@@ -56,7 +56,7 @@ void jj_param_eeprom_init(void)
|
|||||||
*/
|
*/
|
||||||
void jj_param_write(void)
|
void jj_param_write(void)
|
||||||
{
|
{
|
||||||
for (uint8 i = 0; i < DATA_IN_FLASH_NUM - 1; i++) {
|
for (uint8 i = 0; i < DATA_IN_FLASH_NUM ; i++) {
|
||||||
switch (Param_Data[i].type) {
|
switch (Param_Data[i].type) {
|
||||||
case EFLOAT:
|
case EFLOAT:
|
||||||
iic_buffer[i].f32 = *((float *)(Param_Data[i].p_data));
|
iic_buffer[i].f32 = *((float *)(Param_Data[i].p_data));
|
||||||
@@ -80,7 +80,7 @@ void jj_param_write(void)
|
|||||||
*/
|
*/
|
||||||
void jj_param_read(void)
|
void jj_param_read(void)
|
||||||
{
|
{
|
||||||
for (uint8 i = 0; i < DATA_IN_FLASH_NUM - 1; i++) {
|
for (uint8 i = 0; i < DATA_IN_FLASH_NUM ; i++) {
|
||||||
|
|
||||||
eep_soft_iic_read_8bit_registers(&eeprom_param, (4 * i) >> 8, (4 * i), (uint8 *)&iic_buffer[i], 4);
|
eep_soft_iic_read_8bit_registers(&eeprom_param, (4 * i) >> 8, (4 * i), (uint8 *)&iic_buffer[i], 4);
|
||||||
switch (Param_Data[i].type) {
|
switch (Param_Data[i].type) {
|
||||||
|
|||||||
@@ -43,6 +43,7 @@ typedef enum {
|
|||||||
pos_Ki1,
|
pos_Ki1,
|
||||||
pos_Kd1,
|
pos_Kd1,
|
||||||
param_set_speed1,
|
param_set_speed1,
|
||||||
|
|
||||||
DATA_IN_FLASH_NUM,
|
DATA_IN_FLASH_NUM,
|
||||||
|
|
||||||
delta_x,
|
delta_x,
|
||||||
|
|||||||
@@ -7,8 +7,8 @@
|
|||||||
#define LINE_HEAD 0
|
#define LINE_HEAD 0
|
||||||
#define LINE_END Page2_head - 1
|
#define LINE_END Page2_head - 1
|
||||||
static char Text[] = "Param_pid0";
|
static char Text[] = "Param_pid0";
|
||||||
static int event_flag = 0;
|
static int event_flag = 0;
|
||||||
static int index_power = 0;
|
static int index_power = 0;
|
||||||
static int8_t Curser = LINE_HEAD; // 定义光标位置
|
static int8_t Curser = LINE_HEAD; // 定义光标位置
|
||||||
static int8_t Curser_Last = LINE_HEAD; // 定义光标位置
|
static int8_t Curser_Last = LINE_HEAD; // 定义光标位置
|
||||||
static void jj_param_show();
|
static void jj_param_show();
|
||||||
@@ -26,15 +26,14 @@ static void Setup()
|
|||||||
{
|
{
|
||||||
ips200_clear();
|
ips200_clear();
|
||||||
Print_Curser(Curser, Curser_Last, RGB565_PURPLE);
|
Print_Curser(Curser, Curser_Last, RGB565_PURPLE);
|
||||||
for (int16 i = LINE_HEAD; i < LINE_END; i++) {
|
for (int16 i = 0; i <= LINE_END; i++) {
|
||||||
ips200_show_string(0, i * 18 + 2, Param_Data[i].text);
|
ips200_show_string(0, i * 18 + 2, Param_Data[i].text);
|
||||||
if (Param_Data[i].type == EINT32)
|
if (Param_Data[i].type == EINT32)
|
||||||
ips200_show_int(50, i * 18 + 2, *((int32 *)(Param_Data[i].p_data)), 5);
|
ips200_show_int(50, i * 18 + 2, *((int32 *)(Param_Data[i].p_data)), 5);
|
||||||
else if (Param_Data[i].type == EFLOAT)
|
else if (Param_Data[i].type == EFLOAT)
|
||||||
ips200_show_float(50, i * 18 + 2, *((float *)(Param_Data[i].p_data)), 4, 5);
|
ips200_show_float(50, i * 18 + 2, *((float *)(Param_Data[i].p_data)), 4, 5);
|
||||||
}
|
}
|
||||||
ips200_show_int(100, 2, index_power, 5);
|
ips200_show_int(100, 2, index_power, 5);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -89,7 +88,7 @@ static void Event(page_event event)
|
|||||||
} else if (1 == event_flag) {
|
} else if (1 == event_flag) {
|
||||||
if (page_event_forward == event) {
|
if (page_event_forward == event) {
|
||||||
if (Param_Data[Curser].type == EFLOAT) {
|
if (Param_Data[Curser].type == EFLOAT) {
|
||||||
*((float *)(Param_Data[Curser].p_data)) += powf(10.0f,(float)index_power);
|
*((float *)(Param_Data[Curser].p_data)) += powf(10.0f, (float)index_power);
|
||||||
} else if (Param_Data[Curser].type == EINT32) {
|
} else if (Param_Data[Curser].type == EINT32) {
|
||||||
*((int32 *)(Param_Data[Curser].p_data)) += 1;
|
*((int32 *)(Param_Data[Curser].p_data)) += 1;
|
||||||
} else if (Param_Data[Curser].type == EUINT32) {
|
} else if (Param_Data[Curser].type == EUINT32) {
|
||||||
@@ -97,7 +96,7 @@ static void Event(page_event event)
|
|||||||
}
|
}
|
||||||
} else if (page_event_backward == event) {
|
} else if (page_event_backward == event) {
|
||||||
if (Param_Data[Curser].type == EFLOAT) {
|
if (Param_Data[Curser].type == EFLOAT) {
|
||||||
*((float *)(Param_Data[Curser].p_data)) -=powf(10.0f,(float)index_power);
|
*((float *)(Param_Data[Curser].p_data)) -= powf(10.0f, (float)index_power);
|
||||||
} else if (Param_Data[Curser].type == EINT32) {
|
} else if (Param_Data[Curser].type == EINT32) {
|
||||||
*((int32 *)(Param_Data[Curser].p_data)) -= 1;
|
*((int32 *)(Param_Data[Curser].p_data)) -= 1;
|
||||||
} else if (Param_Data[Curser].type == EUINT32) {
|
} else if (Param_Data[Curser].type == EUINT32) {
|
||||||
|
|||||||
@@ -4,11 +4,11 @@
|
|||||||
#include "page.h"
|
#include "page.h"
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
#define LINE_HEAD Page2_head
|
#define LINE_HEAD 0
|
||||||
#define LINE_END DATA_IN_FLASH_NUM
|
#define LINE_END DATA_IN_FLASH_NUM - 1 - Page2_head
|
||||||
static char Text[] = "Param_pid1";
|
static char Text[] = "Param_pid1";
|
||||||
static int event_flag = 0;
|
static int event_flag = 0;
|
||||||
static int index_power = 0;
|
static int index_power = 0;
|
||||||
static int8_t Curser = LINE_HEAD; // 定义光标位置
|
static int8_t Curser = LINE_HEAD; // 定义光标位置
|
||||||
static int8_t Curser_Last = LINE_HEAD; // 定义光标位置
|
static int8_t Curser_Last = LINE_HEAD; // 定义光标位置
|
||||||
static void jj_param_show();
|
static void jj_param_show();
|
||||||
@@ -26,15 +26,14 @@ static void Setup()
|
|||||||
{
|
{
|
||||||
ips200_clear();
|
ips200_clear();
|
||||||
Print_Curser(Curser, Curser_Last, RGB565_PURPLE);
|
Print_Curser(Curser, Curser_Last, RGB565_PURPLE);
|
||||||
for (int16 i = 0; i <= DATA_IN_FLASH_NUM - Page2_head; i++) {
|
for (int16 i = 0; i < 10; i++) {
|
||||||
ips200_show_string(0, i * 18 + 2, Param_Data[i+Page2_head].text);
|
ips200_show_string(0, i * 18 + 2, Param_Data[i + 13].text);
|
||||||
if (Param_Data[i].type == EINT32)
|
if (Param_Data[i + 13].type == EINT32)
|
||||||
ips200_show_int(50, i * 18 + 2, *((int32 *)(Param_Data[i+Page2_head].p_data)), 5);
|
ips200_show_int(50, i * 18 + 2, *((int32 *)(Param_Data[i + 13].p_data)), 5);
|
||||||
else if (Param_Data[i].type == EFLOAT)
|
else if (Param_Data[i + 13].type == EFLOAT)
|
||||||
ips200_show_float(50, i * 18 + 2, *((float *)(Param_Data[i+Page2_head].p_data)), 4, 5);
|
ips200_show_float(50, i * 18 + 2, *((float *)(Param_Data[i + 13].p_data)), 4, 5);
|
||||||
}
|
}
|
||||||
ips200_show_int(100, 2, index_power, 5);
|
ips200_show_int(100, 2, index_power, 5);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -88,20 +87,20 @@ static void Event(page_event event)
|
|||||||
Print_Curser(Curser, Curser_Last, RGB565_PURPLE);
|
Print_Curser(Curser, Curser_Last, RGB565_PURPLE);
|
||||||
} else if (1 == event_flag) {
|
} else if (1 == event_flag) {
|
||||||
if (page_event_forward == event) {
|
if (page_event_forward == event) {
|
||||||
if (Param_Data[Curser].type == EFLOAT) {
|
if (Param_Data[Curser + 13].type == EFLOAT) {
|
||||||
*((float *)(Param_Data[Curser].p_data)) += powf(10.0f,(float)index_power);
|
*((float *)(Param_Data[Curser + 13].p_data)) += powf(10.0f, (float)index_power);
|
||||||
} else if (Param_Data[Curser].type == EINT32) {
|
} else if (Param_Data[Curser + 13].type == EINT32) {
|
||||||
*((int32 *)(Param_Data[Curser].p_data)) += 1;
|
*((int32 *)(Param_Data[Curser + 13].p_data)) += 1;
|
||||||
} else if (Param_Data[Curser].type == EUINT32) {
|
} else if (Param_Data[Curser + 13].type == EUINT32) {
|
||||||
*((uint32 *)(Param_Data[Curser].p_data)) += 1;
|
*((uint32 *)(Param_Data[Curser + Page2_head].p_data)) += 1;
|
||||||
}
|
}
|
||||||
} else if (page_event_backward == event) {
|
} else if (page_event_backward == event) {
|
||||||
if (Param_Data[Curser].type == EFLOAT) {
|
if (Param_Data[Curser + Page2_head].type == EFLOAT) {
|
||||||
*((float *)(Param_Data[Curser].p_data)) -=powf(10.0f,(float)index_power);
|
*((float *)(Param_Data[Curser + Page2_head].p_data)) -= powf(10.0f, (float)index_power);
|
||||||
} else if (Param_Data[Curser].type == EINT32) {
|
} else if (Param_Data[Curser + Page2_head].type == EINT32) {
|
||||||
*((int32 *)(Param_Data[Curser].p_data)) -= 1;
|
*((int32 *)(Param_Data[Curser + Page2_head].p_data)) -= 1;
|
||||||
} else if (Param_Data[Curser].type == EUINT32) {
|
} else if (Param_Data[Curser + Page2_head].type == EUINT32) {
|
||||||
*((uint32 *)(Param_Data[Curser].p_data)) -= 1;
|
*((uint32 *)(Param_Data[Curser + Page2_head].p_data)) -= 1;
|
||||||
}
|
}
|
||||||
} else if (page_event_press_short == event) {
|
} else if (page_event_press_short == event) {
|
||||||
index_power++;
|
index_power++;
|
||||||
@@ -118,12 +117,12 @@ static void Event(page_event event)
|
|||||||
}
|
}
|
||||||
static void jj_param_show()
|
static void jj_param_show()
|
||||||
{
|
{
|
||||||
if (EINT32 == Param_Data[Curser+Page2_head].type)
|
if (EINT32 == Param_Data[Curser + 13].type)
|
||||||
ips200_show_int(50, Curser * 18 + 2, *((int32 *)(Param_Data[Curser+Page2_head].p_data)), 5);
|
ips200_show_int(50, Curser * 18 + 2, *((int32 *)(Param_Data[Curser + 13].p_data)), 5);
|
||||||
else if (EUINT32 == Param_Data[Curser+Page2_head].type)
|
else if (EUINT32 == Param_Data[Curser + 13].type)
|
||||||
ips200_show_uint(50, Curser * 18 + 2, *((int32 *)(Param_Data[Curser+Page2_head].p_data)), 5);
|
ips200_show_uint(50, Curser * 18 + 2, *((int32 *)(Param_Data[Curser + 13].p_data)), 5);
|
||||||
else if (EFLOAT == Param_Data[Curser+Page2_head].type)
|
else if (EFLOAT == Param_Data[Curser + 13].type)
|
||||||
ips200_show_float(50, Curser * 18 + 2, *((float *)(Param_Data[Curser+Page2_head].p_data)), 4, 5);
|
ips200_show_float(50, Curser * 18 + 2, *((float *)(Param_Data[Curser + 13].p_data)), 4, 5);
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* @brief 页面注册函数
|
* @brief 页面注册函数
|
||||||
|
|||||||
Reference in New Issue
Block a user