From e4e0d59ad54033923cd8ffaf3573beed53cfc6ca Mon Sep 17 00:00:00 2001 From: NYiwtisolatedall <269785461@qq.com> Date: Fri, 8 Mar 2024 13:34:18 +0800 Subject: [PATCH] 1. Solved the problem of temperature not refreshing; 2. Modified the upper limit of FocusMaxPos to 2e6. --- indi-qhy/qhy_focuser.cpp | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/indi-qhy/qhy_focuser.cpp b/indi-qhy/qhy_focuser.cpp index 0871281dc..f5f71d984 100644 --- a/indi-qhy/qhy_focuser.cpp +++ b/indi-qhy/qhy_focuser.cpp @@ -100,6 +100,8 @@ bool QFocuser::initProperties() FocusAbsPosN[0].value = 0; FocusAbsPosN[0].step = 1000; + FocusMaxPosN[0].max = 2e6; + FocusSpeedMin = 0; FocusSpeedMax = 8; @@ -268,7 +270,7 @@ int QFocuser::ReadResponse(char *buf) } else if (cmd_id == 1) { - LOGF_INFO(" %s", cmd_json.dump().c_str()); + LOGF_DEBUG(" %s", cmd_json.dump().c_str()); if (cmd_json.find("id") != cmd_json.end() && cmd_json.find("version") != cmd_json.end() && cmd_json.find("bv") != cmd_json.end()) { cmd_version = cmd_json["version"]; @@ -381,15 +383,15 @@ bool QFocuser::Handshake() FOCUSVersionNP[0].setValue(cmd_version); BOARDVersionNP[0].setValue(cmd_version_board); - LOGF_INFO("FOCUSVersionNP: %d", FOCUSVersionNP[0].getValue()); - LOGF_INFO("BOARDVersionNP: %d", BOARDVersionNP[0].getValue()); + LOGF_DEBUG("FOCUSVersionNP: %d", FOCUSVersionNP[0].getValue()); + LOGF_DEBUG("BOARDVersionNP: %d", BOARDVersionNP[0].getValue()); updateTemperature(); if(cmd_voltage == 0) { std::string command_ = create_cmd(16, true, 0); - LOGF_INFO(" %s", command_.c_str()); + LOGF_DEBUG(" %s", command_.c_str()); ret_chk = SendCommand(const_cast(command_.c_str())); if (ret_chk < 0) @@ -741,14 +743,14 @@ int QFocuser::updateTemperature() auto ret_chk = SendCommand(const_cast(command.c_str())); if (ret_chk < 0) { - LOGF_ERROR("updateTemperature error %d", ret_chk); + LOGF_ERROR("updateTemperature Send error %d", ret_chk); return false; } ret_chk = ReadResponse(ret_cmd); if (ret_chk < 0) { - LOGF_ERROR("updateTemperature error %d", ret_chk); + LOGF_ERROR("updateTemperature Read error %d", ret_chk); return false; } @@ -826,6 +828,16 @@ void QFocuser::GetFocusParams() return; } + if ((ret = updateTemperature()) < 0) + { + TemperatureNP.setState(IPS_ALERT); + TemperatureChipNP.setState(IPS_ALERT); + LOG_ERROR("Unknown error while reading temperature."); + TemperatureNP.apply(); + TemperatureChipNP.apply(); + return; + } + FocusAbsPosNP.s = IPS_OK; IDSetNumber(&FocusAbsPosNP, nullptr);