2023-04-19 23:39:27 +08:00
|
|
|
|
#include <Arduino.h>
|
2023-04-11 19:16:14 +08:00
|
|
|
|
#include "HX711.h"
|
|
|
|
|
#include "OneButton.h"
|
2023-04-12 01:02:52 +08:00
|
|
|
|
#include "Serialcommand.h"
|
|
|
|
|
#include "config.h"
|
2024-07-03 13:12:03 +08:00
|
|
|
|
#include "Ticker.h" //调用Ticker.h库
|
2023-04-13 19:44:23 +08:00
|
|
|
|
#include <soc/rtc_cntl_reg.h>
|
2023-04-19 23:39:27 +08:00
|
|
|
|
#include "motocontrol.h"
|
|
|
|
|
#include "moto.h"
|
|
|
|
|
#include <FastLED.h>
|
2023-04-22 16:59:32 +08:00
|
|
|
|
#include <ESP32Servo.h>
|
2023-05-26 20:01:10 +08:00
|
|
|
|
#include "FoodDeliveryBase.h"
|
2023-07-21 22:58:51 +08:00
|
|
|
|
#include <Preferences.h>
|
2024-07-01 22:40:12 +08:00
|
|
|
|
#include "commser.h"
|
2023-04-25 22:13:04 +08:00
|
|
|
|
|
2023-04-11 19:16:14 +08:00
|
|
|
|
// 角度传感器
|
|
|
|
|
// 收放线电机控制
|
|
|
|
|
// 控制串口直接使用Serial2,用法和Serial一样,如需要还可以用Serial1,但需要映射引脚
|
|
|
|
|
|
|
|
|
|
//---------------------------------
|
|
|
|
|
OneButton button_up(BTN_UP, true);
|
|
|
|
|
OneButton button_down(BTN_DOWN, true);
|
|
|
|
|
OneButton button_checktop(BTN_CT, true);
|
2023-04-24 13:20:49 +08:00
|
|
|
|
|
|
|
|
|
OneButton button_test(BTN_TEST, true);
|
|
|
|
|
|
2023-04-11 19:16:14 +08:00
|
|
|
|
HX711 scale;
|
2023-04-12 01:02:52 +08:00
|
|
|
|
Serialcommand sercomm;
|
2023-04-24 13:20:49 +08:00
|
|
|
|
Servo myservo;
|
2023-04-19 23:39:27 +08:00
|
|
|
|
#define NUM_LEDS 1
|
2023-07-21 22:58:51 +08:00
|
|
|
|
Preferences preferences;
|
|
|
|
|
long wei_offset;
|
2023-04-25 22:13:04 +08:00
|
|
|
|
|
2023-04-19 23:39:27 +08:00
|
|
|
|
CRGB leds[NUM_LEDS];
|
|
|
|
|
Motocontrol motocontrol;
|
2023-06-25 19:00:43 +08:00
|
|
|
|
void led_show(uint8_t cr, uint8_t cg, uint8_t cb);
|
2023-04-13 19:44:23 +08:00
|
|
|
|
void sendinfo();
|
2024-07-02 21:29:01 +08:00
|
|
|
|
Ticker tksendinfo; // 发送状态
|
2024-07-02 18:24:51 +08:00
|
|
|
|
|
2023-04-19 23:39:27 +08:00
|
|
|
|
// 收
|
2023-04-11 19:16:14 +08:00
|
|
|
|
void upbtn_click();
|
2023-04-19 23:39:27 +08:00
|
|
|
|
void upbtn_dbclick();
|
|
|
|
|
void upbtn_pressstart();
|
|
|
|
|
void upbtn_pressend();
|
|
|
|
|
// 放
|
2023-04-11 19:16:14 +08:00
|
|
|
|
void downbtn_click();
|
2023-04-19 23:39:27 +08:00
|
|
|
|
void downbtn_dbclick();
|
|
|
|
|
void downbtn_pressstart();
|
|
|
|
|
void downbtn_pressend();
|
|
|
|
|
// 顶抬起
|
2023-04-11 19:16:14 +08:00
|
|
|
|
void ctbtn_pressend();
|
2023-04-19 23:39:27 +08:00
|
|
|
|
// 顶按下
|
2023-04-11 19:16:14 +08:00
|
|
|
|
void ctbtn_pressstart();
|
2023-04-19 23:39:27 +08:00
|
|
|
|
|
2023-04-24 13:20:49 +08:00
|
|
|
|
void testbtn_click();
|
2023-05-27 14:54:14 +08:00
|
|
|
|
void btn_presssatonce();
|
2023-04-24 13:20:49 +08:00
|
|
|
|
|
2023-04-13 19:44:23 +08:00
|
|
|
|
int get_pullweight();
|
|
|
|
|
void Task1(void *pvParameters);
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// void led_show(CRGB ledcolor);
|
|
|
|
|
// void Task1code( void *pvParameters );
|
2023-04-19 23:39:27 +08:00
|
|
|
|
void showledidel();
|
2024-07-02 18:24:51 +08:00
|
|
|
|
int pullweight = 0; // 检测重量-克
|
|
|
|
|
int pullweightoktimes = 0; // 校准成功次数
|
|
|
|
|
int8_t btn_pressatonce = 0; // 是否同时按下
|
2023-04-24 13:20:49 +08:00
|
|
|
|
unsigned long _tm_bengstop;
|
|
|
|
|
bool _bengstop = false;
|
2023-04-25 22:13:04 +08:00
|
|
|
|
bool _needweightalign = false;
|
2023-05-27 14:54:14 +08:00
|
|
|
|
|
2024-07-02 18:24:51 +08:00
|
|
|
|
HookStatus _lasthooktatus = HS_UnInit; // 前一个钩子状态
|
|
|
|
|
bool curr_armed = false;
|
|
|
|
|
uint8_t curr_mode = 0;
|
|
|
|
|
bool _checkweightcal = false; // 检测是否要检测称重传感器是否需要校准
|
|
|
|
|
uint8_t _checkweighttimes = 0; //
|
2023-08-16 23:34:11 +08:00
|
|
|
|
unsigned long _tm_checkweigh;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
static const char *MOUDLENAME = "MAIN";
|
2023-07-21 22:58:51 +08:00
|
|
|
|
// 称重校准状态
|
|
|
|
|
enum Weightalign_status
|
|
|
|
|
{
|
|
|
|
|
WAS_NotAlign,
|
|
|
|
|
WAS_Aligning,
|
|
|
|
|
WAS_AlignOK,
|
|
|
|
|
WAS_Alignfault
|
|
|
|
|
} _weightalign_status;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
unsigned long _weightalign_begintm; // 校准开始时间
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 需要做的初始化工作
|
2024-07-01 22:40:12 +08:00
|
|
|
|
|
|
|
|
|
Initstatus initstatus;
|
2023-04-25 22:13:04 +08:00
|
|
|
|
unsigned long _tm_waitinit;
|
2023-05-26 20:01:10 +08:00
|
|
|
|
|
2023-04-11 19:16:14 +08:00
|
|
|
|
void setup()
|
|
|
|
|
{
|
2023-04-19 23:39:27 +08:00
|
|
|
|
WRITE_PERI_REG(RTC_CNTL_BROWN_OUT_REG, 0); // 关闭低电压检测,避免无限重启
|
|
|
|
|
// 启用Esp32双核第二个核心
|
|
|
|
|
xTaskCreatePinnedToCore(Task1, "Task1", 10000, NULL, 1, NULL, 0); // 最后一个参数至关重要,决定这个任务创建在哪个核上.PRO_CPU 为 0, APP_CPU 为 1,或者 tskNO_AFFINITY 允许任务在两者上运行.
|
2023-04-13 19:44:23 +08:00
|
|
|
|
|
2023-04-11 19:16:14 +08:00
|
|
|
|
// 调试串口
|
2023-07-29 18:05:45 +08:00
|
|
|
|
Serial.begin(57600);
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGI(MOUDLENAME, "Starting PullupDevice... Ver:%s", VERSION);
|
2023-07-21 22:58:51 +08:00
|
|
|
|
preferences.begin("PullupDev", false);
|
|
|
|
|
wei_offset = preferences.getLong("wei_offset", 0);
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "wei_offset:%d", wei_offset);
|
2023-05-26 20:01:10 +08:00
|
|
|
|
|
2023-04-11 19:16:14 +08:00
|
|
|
|
// 初始化按钮
|
|
|
|
|
button_up.attachClick(upbtn_click);
|
2023-04-19 23:39:27 +08:00
|
|
|
|
button_up.attachDoubleClick(upbtn_dbclick);
|
|
|
|
|
button_up.attachLongPressStart(upbtn_pressstart);
|
|
|
|
|
button_up.attachLongPressStop(upbtn_pressend);
|
|
|
|
|
|
|
|
|
|
button_down.attachDoubleClick(downbtn_dbclick);
|
2023-04-11 19:16:14 +08:00
|
|
|
|
button_down.attachClick(downbtn_click);
|
2023-04-19 23:39:27 +08:00
|
|
|
|
button_down.attachLongPressStart(downbtn_pressstart);
|
|
|
|
|
button_down.attachLongPressStop(downbtn_pressend);
|
|
|
|
|
|
2023-04-11 19:16:14 +08:00
|
|
|
|
button_checktop.setPressTicks(10); // 10毫秒就产生按下事件,用于顶部按钮检测
|
|
|
|
|
button_checktop.attachLongPressStart(ctbtn_pressstart); // 按下马上产生事件,
|
|
|
|
|
button_checktop.attachLongPressStop(ctbtn_pressend); // 抬起
|
2023-04-13 19:44:23 +08:00
|
|
|
|
|
2023-04-24 13:20:49 +08:00
|
|
|
|
button_test.attachClick(testbtn_click);
|
2023-04-22 16:59:32 +08:00
|
|
|
|
|
2023-04-24 13:20:49 +08:00
|
|
|
|
ESP32PWM::allocateTimer(0);
|
|
|
|
|
ESP32PWM::allocateTimer(1);
|
|
|
|
|
ESP32PWM::allocateTimer(2);
|
|
|
|
|
ESP32PWM::allocateTimer(3);
|
|
|
|
|
myservo.setPeriodHertz(50); // standard 50 hz servo
|
|
|
|
|
myservo.attach(SERVO_PIN, 1000, 2000); // attaches the servo on pin 18 to the servo object
|
2023-04-22 16:59:32 +08:00
|
|
|
|
|
2023-04-19 23:39:27 +08:00
|
|
|
|
// 初始化RGB LED 显示黄色灯表示需要注意 LED
|
2023-04-25 22:13:04 +08:00
|
|
|
|
FastLED.addLeds<WS2812, LED_DATA_PIN, RGB>(leds, NUM_LEDS); // GRB ordering is typical
|
2023-05-12 00:13:59 +08:00
|
|
|
|
if (!motocontrol.init(&myservo)) // 初始化电机控制
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGE(MOUDLENAME, "motocontrol init fault");
|
|
|
|
|
|
2023-04-25 22:13:04 +08:00
|
|
|
|
initstatus = IS_WaitStart;
|
|
|
|
|
_tm_waitinit = millis();
|
2024-07-02 18:24:51 +08:00
|
|
|
|
_needweightalign = (wei_offset == 0);
|
|
|
|
|
|
|
|
|
|
led_show(255, 255, 255); // 连接wifi中
|
|
|
|
|
|
2023-05-26 20:01:10 +08:00
|
|
|
|
/////////////////////////////////MQTT_语音_MAVLINK 部分
|
|
|
|
|
/*初始化*/
|
2024-07-02 18:24:51 +08:00
|
|
|
|
Serial1.begin(115200, SERIAL_8N1, SERIAL_REPORT_RX, SERIAL_REPORT_TX); // 声音模块引串口脚映射
|
2024-05-30 17:33:53 +08:00
|
|
|
|
fc.playText("开始启动");
|
2024-07-02 18:24:51 +08:00
|
|
|
|
fc.connectWifi(); // 连接wifi
|
2024-07-02 21:29:01 +08:00
|
|
|
|
// fc.playText("正在连接服务器");
|
|
|
|
|
// fc.connectMqtt("cmd"); // 连接mqtt
|
2024-07-02 18:24:51 +08:00
|
|
|
|
fc.mqttClient->setCallback(mqtt_receiveCallback); // 设置订阅成功 回调
|
|
|
|
|
fc.mav_request_data(); // 指定飞控串口返回的数据类别(飞控启动之后发送才有意义)
|
2023-05-26 20:01:10 +08:00
|
|
|
|
|
|
|
|
|
/*异步线程*/
|
2024-07-02 21:29:01 +08:00
|
|
|
|
tksendinfo.attach(1, sendinfo); // 发送状态
|
|
|
|
|
pubTicker.attach(1, pubThread); // 定时 发布主题
|
2024-07-03 15:21:33 +08:00
|
|
|
|
mavTicker.attach(50, mavThread); // 定时 指定飞控mavlink 串口返回的数据类别 防止飞控启动滞后
|
2023-05-26 20:01:10 +08:00
|
|
|
|
/////////////////////////////////MQTT_语音_MAVLINK 部分结束
|
|
|
|
|
|
2023-04-19 23:39:27 +08:00
|
|
|
|
// if (motocontrol.getstatus()==MS_Stop)
|
|
|
|
|
// {
|
|
|
|
|
// //slowup();
|
|
|
|
|
|
|
|
|
|
// }
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGI(MOUDLENAME, "PullupDevice is ready!");
|
|
|
|
|
// fc.mav_send_text(MAV_SEVERITY_INFO,"PullupDevice is ready!");
|
2023-04-11 19:16:14 +08:00
|
|
|
|
}
|
2023-04-19 23:39:27 +08:00
|
|
|
|
void slowup()
|
|
|
|
|
{
|
|
|
|
|
// motocontrol.setspeed(SPEED_UP_SLOW);
|
|
|
|
|
// motocontrol.up(0); //一直收线直到到顶部
|
|
|
|
|
}
|
2023-08-16 23:34:11 +08:00
|
|
|
|
void checkstatus()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
HookStatus vhooktatus = motocontrol.gethooktatus();
|
|
|
|
|
// 入仓把云台回中
|
|
|
|
|
if ((_lasthooktatus != vhooktatus) && (vhooktatus == HS_InStore))
|
|
|
|
|
fc.Camera_action_ret();
|
2023-08-16 23:34:11 +08:00
|
|
|
|
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (_checkweightcal && (vhooktatus == HS_Stop))
|
2023-08-16 23:34:11 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 第一次进来
|
|
|
|
|
if (_lasthooktatus != vhooktatus)
|
|
|
|
|
_tm_checkweigh = millis();
|
2023-08-16 23:34:11 +08:00
|
|
|
|
else
|
2024-07-02 18:24:51 +08:00
|
|
|
|
{ // 1秒内检测连续大于5次就认为重了
|
|
|
|
|
if ((millis() - _tm_checkweigh) < 1000)
|
|
|
|
|
{
|
|
|
|
|
if (abs(pullweight) > 100)
|
|
|
|
|
_checkweighttimes++;
|
|
|
|
|
else
|
|
|
|
|
_checkweighttimes = 0;
|
|
|
|
|
// ESP_LOGD(MOUDLENAME,"check neet tare %d ",pullweight);
|
|
|
|
|
if (_checkweighttimes > 10)
|
|
|
|
|
{
|
|
|
|
|
_checkweightcal = false;
|
|
|
|
|
// ESP_LOGD(MOUDLENAME,"check neet tare %d ",pullweight);
|
|
|
|
|
fc.playText("检测到有货物请确认,如果是空钩请在pad上校准重量");
|
2023-08-16 23:34:11 +08:00
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
_checkweightcal = false;
|
|
|
|
|
}
|
2023-08-16 23:34:11 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
_lasthooktatus = vhooktatus;
|
|
|
|
|
// printf("msend: 1:%.2f,2:%.2f\n",msg_cmd.param1,msg_cmd.param2);
|
2023-08-16 23:34:11 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 1秒调用一次了发mqtt到地面
|
2023-04-19 23:39:27 +08:00
|
|
|
|
void showinfo()
|
|
|
|
|
{
|
2023-05-12 00:13:59 +08:00
|
|
|
|
// moto_measure_t mf=motocontrol.getmotoinfo() ;
|
|
|
|
|
// printf("total_cnt:%.3f;speed:%.2f,curr:%.2fA \n ", mf.output_round_cnt, mf.output_speed_rpm,(float)mf.real_current/1000.0f);
|
2023-04-25 22:13:04 +08:00
|
|
|
|
// if (pullweight > 10)
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// printf("PullWeight:%d\n", pullweight); //发送重量到mqtt
|
|
|
|
|
|
2024-07-02 21:29:01 +08:00
|
|
|
|
topicPubMsg[14] = motocontrol.gethooktatus_str();
|
|
|
|
|
topicPubMsg[13] = pullweight;
|
2023-04-25 22:13:04 +08:00
|
|
|
|
|
2023-05-12 00:13:59 +08:00
|
|
|
|
// control_status_t cs=motocontrol.getcontrolstatus() ;
|
2023-04-25 22:13:04 +08:00
|
|
|
|
|
|
|
|
|
// printf("hooktatus:%d motostatus:%d \n ", hs,cs.motostatus);
|
2024-07-02 18:24:51 +08:00
|
|
|
|
HookStatus vhooktatus = motocontrol.gethooktatus();
|
2023-06-27 22:40:29 +08:00
|
|
|
|
mavlink_command_long_t msg_cmd;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
msg_cmd.command = MAV_CMD_FC_HOOK_STATUS;
|
|
|
|
|
msg_cmd.param1 = vhooktatus;
|
|
|
|
|
msg_cmd.param2 = pullweight;
|
2023-06-27 22:40:29 +08:00
|
|
|
|
msg_cmd.target_system = 1;
|
|
|
|
|
msg_cmd.target_component = 1;
|
|
|
|
|
msg_cmd.confirmation = 0;
|
|
|
|
|
fc.mav_send_command(msg_cmd);
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 校准称重
|
2023-07-21 22:58:51 +08:00
|
|
|
|
void begin_tare()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "begin_tare");
|
|
|
|
|
_weightalign_status = WAS_Aligning;
|
2023-07-21 22:58:51 +08:00
|
|
|
|
_needweightalign = true;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
_weightalign_begintm = millis();
|
2023-07-21 22:58:51 +08:00
|
|
|
|
}
|
|
|
|
|
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 检查校准结果
|
2023-07-21 22:58:51 +08:00
|
|
|
|
bool check_tare()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (_weightalign_status != WAS_Aligning)
|
|
|
|
|
return false;
|
|
|
|
|
// 超时失败
|
|
|
|
|
if ((millis() - _weightalign_begintm) > 2000)
|
2023-07-21 22:58:51 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
_weightalign_status = WAS_Alignfault;
|
2023-07-21 22:58:51 +08:00
|
|
|
|
return false;
|
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if ((pullweight < 10) && ((pullweight > -10)))
|
2023-07-21 22:58:51 +08:00
|
|
|
|
{
|
|
|
|
|
pullweightoktimes++;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (pullweightoktimes > 20)
|
2023-07-21 22:58:51 +08:00
|
|
|
|
{
|
|
|
|
|
_needweightalign = false;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
_weightalign_status = WAS_AlignOK;
|
|
|
|
|
wei_offset = scale.get_offset();
|
2023-07-21 22:58:51 +08:00
|
|
|
|
preferences.putLong("wei_offset", wei_offset);
|
|
|
|
|
motocontrol.weightalign(true);
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "check_tare ok: %d,offset:%d", pullweight, wei_offset);
|
2023-07-21 22:58:51 +08:00
|
|
|
|
return true;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
_needweightalign = true;
|
2023-07-21 22:58:51 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// 没成功继续校准
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "weight not zero: %d", pullweight);
|
2023-07-21 22:58:51 +08:00
|
|
|
|
_needweightalign = true;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
pullweightoktimes = 0;
|
2023-07-21 22:58:51 +08:00
|
|
|
|
}
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 初始化过程--
|
|
|
|
|
// 先收线到顶,确定线的0点位置,再下降2cm开始称重归零(到顶部后有压力,重量不准,需要降一点),再上升到顶,初始化完成
|
|
|
|
|
//
|
|
|
|
|
void checkinited()
|
|
|
|
|
{
|
|
|
|
|
switch (initstatus)
|
|
|
|
|
{
|
2023-04-25 22:13:04 +08:00
|
|
|
|
case Initstatus::IS_WaitStart:
|
|
|
|
|
{
|
|
|
|
|
if ((millis() - _tm_waitinit) > 500)
|
|
|
|
|
initstatus = IS_Start;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
2023-04-24 13:20:49 +08:00
|
|
|
|
case Initstatus::IS_Start:
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 一开始没有锁定状态
|
2023-04-25 22:13:04 +08:00
|
|
|
|
if (motocontrol.gethooktatus() != HS_Locked)
|
|
|
|
|
{
|
|
|
|
|
// 开始自动慢速上升,直到顶部按钮按下
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "IS_Start: startup wait locked");
|
2023-04-25 22:13:04 +08:00
|
|
|
|
motocontrol.setspeed(SPEED_BTN_SLOW);
|
|
|
|
|
motocontrol.moto_run(MotoStatus::MS_Up);
|
|
|
|
|
initstatus = IS_Wait_Locked;
|
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
else // 开机就是锁定状态--开始校准称重传感器
|
2023-04-25 22:13:04 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
initstatus = IS_begin_WeightZero;
|
2023-04-25 22:13:04 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
2023-04-25 22:13:04 +08:00
|
|
|
|
case Initstatus::IS_Wait_Locked:
|
2023-04-24 13:20:49 +08:00
|
|
|
|
{
|
|
|
|
|
if (motocontrol.gethooktatus() == HS_Locked)
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "IS_Wait_LengthZero: is locked");
|
2023-07-21 22:58:51 +08:00
|
|
|
|
initstatus = IS_begin_WeightZero;
|
2023-04-24 13:20:49 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
2023-04-19 23:39:27 +08:00
|
|
|
|
|
2024-07-02 18:24:51 +08:00
|
|
|
|
case Initstatus::IS_begin_WeightZero:
|
2023-04-24 13:20:49 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 如果没有保存的校准数据就需要校准
|
|
|
|
|
if (wei_offset != 0)
|
2023-04-24 13:20:49 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "offset is loaded weight: %d,offset:%d", pullweight, wei_offset);
|
2023-07-21 22:58:51 +08:00
|
|
|
|
scale.set_offset(wei_offset);
|
|
|
|
|
motocontrol.weightalign(true);
|
|
|
|
|
_needweightalign = false;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// fc.playText("挂钩已锁定");
|
2023-07-21 22:58:51 +08:00
|
|
|
|
initstatus = IS_OK;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
2023-07-21 22:58:51 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "begin_tare");
|
2023-07-21 22:58:51 +08:00
|
|
|
|
begin_tare();
|
|
|
|
|
initstatus = IS_CheckWeightZero;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
case Initstatus::IS_CheckWeightZero:
|
2023-07-21 22:58:51 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (_weightalign_status == WAS_AlignOK)
|
2023-07-21 22:58:51 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// fc.playText("挂钩已锁定");
|
2023-07-21 22:58:51 +08:00
|
|
|
|
initstatus = IS_OK;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
|
|
|
|
else if (_weightalign_status == WAS_Alignfault)
|
2023-04-24 13:20:49 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "weightalign fault! again");
|
2023-07-21 22:58:51 +08:00
|
|
|
|
initstatus = IS_begin_WeightZero;
|
2023-04-24 13:20:49 +08:00
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
2023-07-21 22:58:51 +08:00
|
|
|
|
|
2023-04-25 22:13:04 +08:00
|
|
|
|
/*
|
|
|
|
|
case Initstatus::IS_LengthZero:
|
|
|
|
|
{
|
|
|
|
|
// 开始自动慢速下降2cm
|
|
|
|
|
printf("IS_LengthZero: Down 2cm \n");
|
|
|
|
|
|
|
|
|
|
motocontrol.setspeed(SPEED_INSTORE);
|
|
|
|
|
motocontrol.moto_run(MotoStatus::MS_Down, 10);
|
|
|
|
|
initstatus = IS_Wait_WeightZero;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
case Initstatus::IS_Wait_WeightZero:
|
|
|
|
|
{
|
|
|
|
|
if (motocontrol.gethooktatus() == HS_Stop)
|
|
|
|
|
{
|
|
|
|
|
printf("IS_Wait_WeightZero: Down Stop start tare and up \n");
|
|
|
|
|
scale.tare();
|
|
|
|
|
motocontrol.weightalign(true);
|
|
|
|
|
motocontrol.moto_run(MotoStatus::MS_Up);
|
|
|
|
|
initstatus = IS_WeightZero;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
case Initstatus::IS_WeightZero:
|
|
|
|
|
{
|
|
|
|
|
if (motocontrol.gethooktatus() == HS_Locked)
|
|
|
|
|
{
|
|
|
|
|
printf("IS_WeightZero: Locked \n");
|
|
|
|
|
initstatus = IS_InStoreLocked;
|
|
|
|
|
}
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
case Initstatus::IS_InStoreLocked:
|
|
|
|
|
{
|
|
|
|
|
printf("IS_InStoreLocked: IS_OK \n");
|
|
|
|
|
initstatus = IS_OK;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
*/
|
2023-04-24 13:20:49 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-05-30 17:33:53 +08:00
|
|
|
|
void set_locked(bool locked)
|
|
|
|
|
{
|
|
|
|
|
motocontrol.setlocked(locked);
|
|
|
|
|
if (locked)
|
|
|
|
|
fc.playText("挂钩已锁定");
|
|
|
|
|
}
|
2023-04-19 23:39:27 +08:00
|
|
|
|
// 在核心1上执行,重要的延迟低的
|
2023-04-13 19:44:23 +08:00
|
|
|
|
void loop()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// sercomm.getcommand(); // 得到控制命令
|
2023-04-19 23:39:27 +08:00
|
|
|
|
button_checktop.tick(); // 按钮
|
|
|
|
|
button_down.tick(); // 按钮
|
|
|
|
|
button_up.tick(); // 按钮
|
2023-04-24 13:20:49 +08:00
|
|
|
|
button_test.tick();
|
|
|
|
|
motocontrol.setweight(pullweight); // 告诉电机拉的重量
|
2023-07-14 17:50:20 +08:00
|
|
|
|
motocontrol.update(); // 电机控制
|
2024-07-02 18:24:51 +08:00
|
|
|
|
|
|
|
|
|
showledidel(); // 显示LED灯光
|
|
|
|
|
checkstatus(); // 检测状态,执行一些和状态有关的功能
|
|
|
|
|
// showinfo(); // 显示一些调试用信息-
|
|
|
|
|
// 到顶后延迟关闭动力电和舵机
|
2023-06-27 02:02:21 +08:00
|
|
|
|
if (_bengstop)
|
2023-04-22 16:59:32 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if ((initstatus == IS_OK) && (pullweight > TM_INSTORE_DELAY_WEIGHT))
|
2023-06-27 02:02:21 +08:00
|
|
|
|
{
|
2023-07-14 17:50:20 +08:00
|
|
|
|
if ((millis() - _tm_bengstop) > TM_INSTORE_WEIGHT_DELAY)
|
2023-06-27 02:02:21 +08:00
|
|
|
|
{
|
|
|
|
|
_bengstop = false;
|
2024-05-30 17:33:53 +08:00
|
|
|
|
set_locked(true);
|
2023-06-27 02:02:21 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
else
|
2023-06-27 02:02:21 +08:00
|
|
|
|
{
|
2023-07-14 17:50:20 +08:00
|
|
|
|
if ((millis() - _tm_bengstop) > TM_INSTORE_NOWEIGHT_DELAY)
|
|
|
|
|
{
|
|
|
|
|
_bengstop = false;
|
2024-05-30 17:33:53 +08:00
|
|
|
|
set_locked(true);
|
2023-07-14 17:50:20 +08:00
|
|
|
|
}
|
2023-06-27 02:02:21 +08:00
|
|
|
|
}
|
2023-04-22 16:59:32 +08:00
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
check_tare(); // 检查看是否需要校准称重
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 检测执行初始化工作
|
|
|
|
|
checkinited();
|
2023-04-19 23:39:27 +08:00
|
|
|
|
delay(1);
|
|
|
|
|
}
|
|
|
|
|
// 在核心0上执行耗时长的低优先级的
|
|
|
|
|
void Task1(void *pvParameters)
|
|
|
|
|
{
|
2023-04-13 19:44:23 +08:00
|
|
|
|
// 初始化称重传感器
|
2024-07-02 18:24:51 +08:00
|
|
|
|
scale.begin(LOADCELL_DOUT_PIN, LOADCELL_SCK_PIN, HX711_GAIN); // 2号机用的B通道,1号用的A通道
|
|
|
|
|
scale.set_scale(WEIGHT_SCALE); // 这是缩放值,根据砝码实测516.f
|
|
|
|
|
scale.tare(); // 重置为0
|
2023-04-19 23:39:27 +08:00
|
|
|
|
|
|
|
|
|
// 在这里可以添加一些代码,这样的话这个任务执行时会先执行一次这里的内容(当然后面进入while循环之后不会再执行这部分了)
|
|
|
|
|
while (1)
|
2023-04-13 19:44:23 +08:00
|
|
|
|
{
|
2023-04-25 22:13:04 +08:00
|
|
|
|
if (_needweightalign)
|
|
|
|
|
{
|
|
|
|
|
_needweightalign = false;
|
|
|
|
|
scale.tare();
|
|
|
|
|
}
|
2023-04-19 23:39:27 +08:00
|
|
|
|
pullweight = get_pullweight();
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 显示重量
|
|
|
|
|
// printf("pullweight: %d \n", pullweight);
|
|
|
|
|
|
2024-07-03 19:43:03 +08:00
|
|
|
|
/////////////////////////////////MQTT_语音_MAVLINK 部分
|
|
|
|
|
/*从飞控拿数据*/
|
|
|
|
|
fc.comm_receive(mavlink_receiveCallback);
|
|
|
|
|
vTaskDelay(1);
|
|
|
|
|
/////////////////////////////////MQTT_语音_MAVLINK 部分结束
|
2024-07-02 21:29:01 +08:00
|
|
|
|
if (fc.checkWiFiStatus())
|
|
|
|
|
/*保持mqtt心跳,如果Mqtt没有连接会自动连接*/
|
|
|
|
|
fc.mqttLoop("cmd");
|
2023-04-13 19:44:23 +08:00
|
|
|
|
vTaskDelay(10);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
void sendinfo() // 每500ms发送状态信息
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// sercomm.sendinfo(motocontrol.gethooktatus(), 5324, pullweight);
|
2023-06-27 22:40:29 +08:00
|
|
|
|
showinfo();
|
2023-04-13 19:44:23 +08:00
|
|
|
|
}
|
2023-04-11 19:16:14 +08:00
|
|
|
|
|
|
|
|
|
float Value;
|
|
|
|
|
#define FILTER_A 0.5
|
|
|
|
|
// 低通滤波和限幅后的拉力数值,单位:克
|
2023-04-13 19:44:23 +08:00
|
|
|
|
int get_pullweight()
|
2023-04-11 19:16:14 +08:00
|
|
|
|
{
|
|
|
|
|
float NewValue;
|
|
|
|
|
if (scale.wait_ready_timeout(100)) // 等待数据ok,100ms超时
|
|
|
|
|
NewValue = scale.get_units();
|
|
|
|
|
else
|
|
|
|
|
NewValue = 0;
|
|
|
|
|
Value = NewValue * FILTER_A + (1.0 - FILTER_A) * Value; // 低通滤波
|
2024-07-02 18:24:51 +08:00
|
|
|
|
Value = constrain(Value, -10000, 10000); // 限制到0-10公斤
|
2023-04-13 19:44:23 +08:00
|
|
|
|
return round(Value);
|
2023-04-11 19:16:14 +08:00
|
|
|
|
}
|
|
|
|
|
// 提示灯光控制
|
2023-04-24 13:20:49 +08:00
|
|
|
|
void led_show(uint8_t cr, uint8_t cg, uint8_t cb)
|
2023-04-11 19:16:14 +08:00
|
|
|
|
{
|
2023-04-24 13:20:49 +08:00
|
|
|
|
leds[0] = CRGB(cg, cr, cb); // 颜色交叉了
|
2023-04-19 23:39:27 +08:00
|
|
|
|
FastLED.show();
|
2023-04-11 19:16:14 +08:00
|
|
|
|
}
|
2023-04-19 23:39:27 +08:00
|
|
|
|
// 显示颜色
|
|
|
|
|
void showledidel()
|
|
|
|
|
{
|
2023-04-25 22:13:04 +08:00
|
|
|
|
// 超重--红色
|
|
|
|
|
if (motocontrol.getcontrolstatus().is_overweight)
|
|
|
|
|
{
|
2023-07-14 17:50:20 +08:00
|
|
|
|
led_show(255, 0, 255); // 紫色
|
2023-04-25 22:13:04 +08:00
|
|
|
|
return;
|
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
switch (motocontrol.gethooktatus())
|
2023-06-27 22:40:29 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
case HookStatus::HS_UnInit:
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
led_show(255, 255, 0); // 黄色
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
case HookStatus::HS_Down:
|
|
|
|
|
case HookStatus::HS_DownSlow:
|
|
|
|
|
case HookStatus::HS_WaitUnhook:
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2023-04-25 22:13:04 +08:00
|
|
|
|
led_show(0, 0, 255); // 蓝色
|
2023-04-19 23:39:27 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
case HookStatus::HS_Up:
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
led_show(200, 0, 50); // 粉红
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
case HookStatus::HS_InStore:
|
|
|
|
|
{
|
|
|
|
|
led_show(255, 0, 0); // 红
|
2023-04-19 23:39:27 +08:00
|
|
|
|
break;
|
|
|
|
|
}
|
2023-04-11 19:16:14 +08:00
|
|
|
|
|
2024-07-02 18:24:51 +08:00
|
|
|
|
case HookStatus::HS_Locked:
|
|
|
|
|
{
|
|
|
|
|
led_show(0, 255, 0); // 绿色
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
case HookStatus::HS_Stop:
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
led_show(255, 255, 255); // 白色
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
|
|
switch (motocontrol.getcontrolstatus().motostatus)
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
case MotoStatus::MS_Down:
|
|
|
|
|
{
|
|
|
|
|
led_show(0, 0, 255); // 蓝色
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
case MotoStatus::MS_Up:
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
if (motocontrol.getcontrolstatus().is_instore)
|
|
|
|
|
led_show(255, 0, 0); // 红
|
2023-04-25 22:13:04 +08:00
|
|
|
|
else
|
2024-07-02 18:24:51 +08:00
|
|
|
|
led_show(200, 0, 50); // 粉红
|
|
|
|
|
break;
|
2023-04-24 13:20:49 +08:00
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
|
|
|
|
|
case MotoStatus::MS_Stop:
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (motocontrol.getcontrolstatus().is_toplocked)
|
|
|
|
|
{
|
|
|
|
|
if (initstatus == IS_OK)
|
|
|
|
|
led_show(0, 255, 0); // 绿色
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Serial.println("not IS_OK");
|
|
|
|
|
led_show(255, 255, 0); // 黄色
|
|
|
|
|
}
|
|
|
|
|
}
|
2023-04-19 23:39:27 +08:00
|
|
|
|
else
|
2023-04-25 22:13:04 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (motocontrol.getcontrolstatus().is_setzero)
|
|
|
|
|
led_show(255, 255, 255); // 白色
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
// Serial.println("not is_setzero");
|
|
|
|
|
led_show(255, 255, 0); // 黄色
|
|
|
|
|
}
|
2023-04-25 22:13:04 +08:00
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
break;
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
|
|
|
|
*/
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/////////////////////////////////////按钮处理
|
|
|
|
|
// 顶部按钮,检测是否到顶部
|
2023-04-11 19:16:14 +08:00
|
|
|
|
void ctbtn_pressstart()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Top_pressstart");
|
|
|
|
|
// 只在上升时停止
|
|
|
|
|
if ((motocontrol.gethooktatus() == HS_UnInit) || (motocontrol.gethooktatus() == HS_Up) || (motocontrol.gethooktatus() == HS_InStore))
|
2023-07-14 17:50:20 +08:00
|
|
|
|
{
|
|
|
|
|
_tm_bengstop = millis();
|
|
|
|
|
_bengstop = true;
|
|
|
|
|
}
|
2023-04-11 19:16:14 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 顶部按钮,抬起
|
2023-04-11 19:16:14 +08:00
|
|
|
|
void ctbtn_pressend()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Top_pressend");
|
2024-05-30 17:33:53 +08:00
|
|
|
|
set_locked(false);
|
2023-04-24 13:20:49 +08:00
|
|
|
|
_bengstop = false;
|
2023-04-11 19:16:14 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
|
2024-07-02 18:24:51 +08:00
|
|
|
|
void down_action(float motospeed, float length = 0.0f)
|
2023-04-11 19:16:14 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Down_action sp:%.2f len:%.2f cm", motospeed, length);
|
2023-07-29 18:05:45 +08:00
|
|
|
|
|
|
|
|
|
if (motocontrol.getcontrolstatus().motostatus != MotoStatus::MS_Stop)
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2023-06-27 02:02:21 +08:00
|
|
|
|
motocontrol.stoprun();
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 如果在自动放线状态,只是恢复自动放线
|
2023-06-27 02:02:21 +08:00
|
|
|
|
if (motocontrol.getcontrolstatus().is_autogoodsdown)
|
|
|
|
|
{
|
|
|
|
|
motocontrol.moto_goodsdownresume();
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
2023-06-27 02:02:21 +08:00
|
|
|
|
{
|
|
|
|
|
motocontrol.setspeed(motospeed);
|
2024-07-02 18:24:51 +08:00
|
|
|
|
motocontrol.moto_run(MotoStatus::MS_Down, length);
|
2024-05-30 17:33:53 +08:00
|
|
|
|
fc.playText("放线");
|
2023-06-27 02:02:21 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
}
|
2023-04-11 19:16:14 +08:00
|
|
|
|
}
|
2023-06-27 02:02:21 +08:00
|
|
|
|
|
|
|
|
|
void up_action(float motospeed)
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Up_action sp:%.2f", motospeed);
|
2023-07-29 18:05:45 +08:00
|
|
|
|
|
2023-06-27 02:02:21 +08:00
|
|
|
|
if (motocontrol.getcontrolstatus().motostatus == MotoStatus::MS_Stop)
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
motocontrol.stopautodown(); // 终止自动放线
|
|
|
|
|
motocontrol.setspeed(motospeed);
|
|
|
|
|
motocontrol.moto_run(MotoStatus::MS_Up);
|
|
|
|
|
fc.playText("收线");
|
|
|
|
|
}
|
|
|
|
|
else
|
2023-06-27 02:02:21 +08:00
|
|
|
|
motocontrol.stoprun();
|
|
|
|
|
}
|
|
|
|
|
// 放线按钮--单击
|
|
|
|
|
void downbtn_click()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Down_click");
|
|
|
|
|
_checkweightcal = true; // 检测是否需要校准称重传感器--在下放停止时检测
|
|
|
|
|
_checkweighttimes = 0;
|
|
|
|
|
down_action(SPEED_BTN_SLOW, 10);
|
2023-06-27 02:02:21 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 放线按钮--双击
|
|
|
|
|
void downbtn_dbclick()
|
2023-04-11 19:16:14 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Down_dbclick");
|
2023-06-27 02:02:21 +08:00
|
|
|
|
down_action(SPEED_BTN_MID);
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 放线按钮--长按
|
|
|
|
|
void downbtn_pressstart()
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Down_pressstart");
|
|
|
|
|
// 两个同时按用于对频
|
2023-05-27 14:54:14 +08:00
|
|
|
|
btn_pressatonce++;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (btn_pressatonce > 2)
|
|
|
|
|
btn_pressatonce = 2;
|
|
|
|
|
if (btn_pressatonce == 2)
|
2023-05-27 14:54:14 +08:00
|
|
|
|
{
|
|
|
|
|
btn_presssatonce();
|
|
|
|
|
return;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
2023-06-27 02:02:21 +08:00
|
|
|
|
down_action(SPEED_BTN_FAST);
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 放线按钮--长按抬起
|
|
|
|
|
void downbtn_pressend()
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Down_pressend");
|
2023-05-27 14:54:14 +08:00
|
|
|
|
btn_pressatonce--;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (btn_pressatonce < 0)
|
|
|
|
|
btn_pressatonce = 0;
|
|
|
|
|
// 不是恢复自动放线抬起按键就停止
|
2023-06-27 02:02:21 +08:00
|
|
|
|
if (!motocontrol.getcontrolstatus().is_autogoodsdown)
|
|
|
|
|
motocontrol.stoprun();
|
2023-04-24 13:20:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 收线按钮-单击
|
|
|
|
|
void upbtn_click()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// fc.mav_send_text(MAV_SEVERITY_INFO,"upbtn_click");
|
|
|
|
|
ESP_LOGD(MOUDLENAME, "UP_click");
|
|
|
|
|
up_action(SPEED_BTN_SLOW);
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 收线按钮-双击
|
|
|
|
|
void upbtn_dbclick()
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "UP_dbclick");
|
2023-06-27 02:02:21 +08:00
|
|
|
|
up_action(SPEED_BTN_MID);
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
2023-05-27 14:54:14 +08:00
|
|
|
|
// 两个按钮同时按下
|
|
|
|
|
void btn_presssatonce()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "UP_presssatonce");
|
|
|
|
|
led_show(255, 255, 255); // 高亮一下
|
2024-05-30 17:33:53 +08:00
|
|
|
|
fc.playText("发送对频信息");
|
2024-07-02 21:29:01 +08:00
|
|
|
|
fc.pubMQTTmsg(topicHandle[0], fc.getMacAdd());
|
2023-05-27 14:54:14 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 收线按钮-长按
|
|
|
|
|
void upbtn_pressstart()
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "UP_pressstart");
|
|
|
|
|
// 两个同时按用于对频
|
2023-05-27 14:54:14 +08:00
|
|
|
|
btn_pressatonce++;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (btn_pressatonce > 2)
|
|
|
|
|
btn_pressatonce = 2;
|
|
|
|
|
if (btn_pressatonce == 2)
|
2023-05-27 14:54:14 +08:00
|
|
|
|
{
|
|
|
|
|
btn_presssatonce();
|
|
|
|
|
return;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
2023-06-27 02:02:21 +08:00
|
|
|
|
up_action(SPEED_BTN_FAST);
|
2023-04-19 23:39:27 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 收线按钮-长按抬起
|
|
|
|
|
void upbtn_pressend()
|
2023-04-19 23:39:27 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "UP_pressend");
|
2023-05-27 14:54:14 +08:00
|
|
|
|
btn_pressatonce--;
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (btn_pressatonce < 0)
|
|
|
|
|
btn_pressatonce = 0;
|
2023-05-27 14:54:14 +08:00
|
|
|
|
|
2023-06-27 02:02:21 +08:00
|
|
|
|
motocontrol.stoprun();
|
2023-04-11 19:16:14 +08:00
|
|
|
|
}
|
2023-04-24 13:20:49 +08:00
|
|
|
|
|
2024-07-02 18:24:51 +08:00
|
|
|
|
// 自动下放
|
2023-06-26 20:09:32 +08:00
|
|
|
|
void Hook_autodown(float length_cm)
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (motocontrol.gethooktatus() == HS_Locked)
|
2023-06-26 20:09:32 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Hook_autodown %.2f cm", length_cm);
|
2023-08-16 23:34:11 +08:00
|
|
|
|
fc.Camera_action_down();
|
2023-06-26 20:09:32 +08:00
|
|
|
|
motocontrol.moto_goodsdown(length_cm); // 二楼340 //桌子40
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
ESP_LOGE(MOUDLENAME, "autodown fault, not HS_Locked ");
|
2023-06-26 20:09:32 +08:00
|
|
|
|
}
|
|
|
|
|
void Hook_stop()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Hook_stop");
|
|
|
|
|
motocontrol.stoprun();
|
2023-06-26 20:09:32 +08:00
|
|
|
|
}
|
|
|
|
|
void Hook_resume()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
if (motocontrol.gethooktatus() == HS_Stop)
|
2023-06-26 20:09:32 +08:00
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Hook_resume");
|
2023-06-26 20:09:32 +08:00
|
|
|
|
motocontrol.moto_goodsdownresume();
|
2024-07-02 18:24:51 +08:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
ESP_LOGE(MOUDLENAME, "resume fault, not HS_Stop ");
|
2023-06-26 20:09:32 +08:00
|
|
|
|
}
|
2023-07-01 21:14:09 +08:00
|
|
|
|
void Hook_recovery()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "Hook_recovery");
|
|
|
|
|
if (motocontrol.gethooktatus() != HS_Locked)
|
|
|
|
|
{
|
|
|
|
|
motocontrol.stoprun();
|
|
|
|
|
up_action(SPEED_HOOK_UP);
|
|
|
|
|
}
|
2023-07-01 21:14:09 +08:00
|
|
|
|
}
|
2023-06-26 20:09:32 +08:00
|
|
|
|
|
2023-04-24 13:20:49 +08:00
|
|
|
|
// 测试按钮
|
|
|
|
|
void testbtn_click()
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "testbtn_click");
|
2023-05-12 00:12:07 +08:00
|
|
|
|
switch (motocontrol.gethooktatus())
|
|
|
|
|
{
|
|
|
|
|
case HS_Locked: // 在顶部--会自动检测是否有物体,有才下放
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "moto_goodsdown");
|
2023-05-12 00:12:07 +08:00
|
|
|
|
motocontrol.moto_goodsdown(22); // 二楼340 //桌子40
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
case HS_Stop:
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "moto_resume");
|
2023-05-12 00:12:07 +08:00
|
|
|
|
|
|
|
|
|
motocontrol.moto_goodsdownresume();
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
default:
|
|
|
|
|
{
|
2024-07-02 18:24:51 +08:00
|
|
|
|
ESP_LOGD(MOUDLENAME, "stop");
|
2023-06-27 02:02:21 +08:00
|
|
|
|
motocontrol.stoprun();
|
2023-05-12 00:12:07 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
2023-05-26 20:01:10 +08:00
|
|
|
|
}
|