You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

244 lines
10 KiB

2 years ago
  1. #include <stddef.h>
  2. #include <stdio.h>
  3. #include "main.hpp"
  4. //
  5. #include "feite_servo_motor.hpp"
  6. #include "sdk/os/zos.hpp"
  7. //
  8. // #include "sdk\components\cmdscheduler\cmd_scheduler.hpp"
  9. #include "sdk\components\eq_20_asb_motor\eq20_servomotor.hpp"
  10. #include "sdk\components\iflytop_can_slave_module_master_end\stepmotor.hpp"
  11. #include "sdk\components\iflytop_can_slave_v1\iflytop_can_master.hpp"
  12. #include "sdk\components\step_motor_45\step_motor_45.hpp"
  13. #include "sdk\components\step_motor_45\step_motor_45_scheduler.hpp"
  14. #include "sdk\components\zcancmder\zcanreceiver_master.hpp"
  15. //
  16. #include "sdk\components/step_motor_ctrl_module/step_motor_ctrl_script_cmder_module.hpp"
  17. #include "sdk\components/xy_robot_ctrl_module/xy_robot_script_cmder_module.hpp"
  18. #include "sdk\components\cmdscheduler\cmd_scheduler_v2.hpp"
  19. #include "sdk\components\eq_20_asb_motor\script_cmder_eq20_servomotor.hpp"
  20. #include "sdk\components\mini_servo_motor\mini_servo_motor_ctrl_module.hpp"
  21. #include "sdk\components\mini_servo_motor\scirpt_cmder_mini_servo_motor_ctrl_module.hpp"
  22. #include "sdk\components\step_motor_45\script_cmder_step_motor_45.hpp"
  23. // #include "sdk\components\scriptcmder_module\xy_robot_script_cmder_module.hpp"
  24. // #include "sdk\components\zcancmder_master_module/zcan_master_step_motor_ctrl_module.hpp"
  25. // #include "sdk\components\zcancmder_master_module\zcan_xy_robot_master_module.hpp"
  26. #include "intelligent_winding_robot_ctrl.hpp"
  27. #include "sdk\components\taojingchi_screen\taojingchi_screen_service.hpp"
  28. #include "sdk\components\zprotocol_helper\micro_computer_module_device_script_cmder_paser.hpp"
  29. #include "sdk\components\zprotocols\zcancmder_v2\protocol_proxy.hpp"
  30. #include "sdk\components\zprotocols\zcancmder_v2\zmodule_device_manager.hpp"
  31. #include "sdk\components\zprotocols\zcancmder_v2\zmodule_device_script_cmder_paser.hpp"
  32. namespace iflytop {
  33. extern Main gmain;
  34. };
  35. using namespace iflytop;
  36. using namespace std;
  37. extern "C" {}
  38. /*******************************************************************************
  39. * *
  40. *******************************************************************************/
  41. #if 0
  42. static StepMotor45::cfg_t cfg4 = {
  43. .max_pos = -1,
  44. .enable_zero_limit = false,
  45. .enable_max_pos_limit = false,
  46. .mirror = true,
  47. .zeroPin = PinNull,
  48. .zeroPinMirror = false,
  49. .driverPin = {PE0, PE2, PE4, PE6},
  50. .driverPinMirror = true,
  51. };
  52. static StepMotor45::cfg_t cfg5 = {
  53. .max_pos = -1,
  54. .enable_zero_limit = false,
  55. .enable_max_pos_limit = false,
  56. .mirror = true,
  57. .zeroPin = PinNull,
  58. .zeroPinMirror = false,
  59. .driverPin = {PC13, PE5, PE3, PE1},
  60. .driverPinMirror = true,
  61. };
  62. static StepMotor45::cfg_t cfg6 = {
  63. .max_pos = -1,
  64. .enable_zero_limit = false,
  65. .enable_max_pos_limit = false,
  66. .mirror = true,
  67. .zeroPin = PinNull,
  68. .zeroPinMirror = false,
  69. .driverPin = {PC12, PD3, PD5, PD7},
  70. .driverPinMirror = true,
  71. };
  72. #endif
  73. namespace iflytop {
  74. /*******************************************************************************
  75. * *
  76. *******************************************************************************/
  77. extern ZCanCommnaderMaster m_zcanCommnaderMaster; // can����
  78. extern ModbusBlockHost g_modbusblockhost; // modbus����
  79. extern FeiTeServoMotor g_feiteservomotor_bus; // ���ض�������
  80. extern ZModuleDeviceManager g_zmodule_device_manager; // ���ڹ������е��豸
  81. extern StepMotor45Scheduler step_motor45_scheduler; // 45��������������
  82. extern CmdSchedulerV2 g_cmdScheduler; // �����ַ���ָ������
  83. extern TaoJingChiScreenService g_taojingchi_screen_service; // �Ծ�����Ļ����
  84. extern MicroComputerModuleDeviceScriptCmderPaser g_zmodule_device_script_cmder_paser; // ���ڽ������е��豸ָ��
  85. /*******************************************************************************
  86. * *
  87. *******************************************************************************/
  88. extern Eq20ServoMotor g_main_servo_motor;
  89. extern StepMotor45 g_step_motor45[7];
  90. extern MiniRobotCtrlModule g_mini_servo[6];
  91. /*******************************************************************************
  92. * CAN *
  93. *******************************************************************************/
  94. extern ZIProtocolProxy g_xyrobotctrlmodule;
  95. extern ZIProtocolProxy g_z_step_motor;
  96. extern IntelligentWindingRobotCtrl g_intelligent_winding_robot_ctrl;
  97. } // namespace iflytop
  98. extern "C" {
  99. extern DMA_HandleTypeDef hdma_usart3_rx;
  100. extern DMA_HandleTypeDef hdma_usart3_tx;
  101. }
  102. extern "C" {}
  103. extern DMA_HandleTypeDef hdma_usart2_rx;
  104. extern DMA_HandleTypeDef hdma_usart2_tx;
  105. void script_reg_fn() {
  106. #if 0
  107. xy_robot_ctrl_enable (id,en)
  108. xy_robot_ctrl_factory_reset (id)
  109. xy_robot_ctrl_flush (id)
  110. xy_robot_ctrl_force_change_current_pos (id,x,y)
  111. xy_robot_ctrl_get_base_param (id)
  112. xy_robot_ctrl_move_by (id,dx,dy,v)
  113. xy_robot_ctrl_move_to (id,x,y,speed)
  114. xy_robot_ctrl_move_to_zero (id)
  115. xy_robot_ctrl_move_to_zero_with_calibrate (id,nowx,nowy)
  116. xy_robot_ctrl_stop (id,stop_type)
  117. #endif
  118. #define XY_ROBOT_ID 3
  119. g_cmdScheduler.regCMD("xy_robot_ctrl_enable", "(id,en)", 2, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  120. int32_t en = atoi(paraV[1]);
  121. int32_t ecode = g_zmodule_device_manager.xymotor_enable(XY_ROBOT_ID, en);
  122. ack->setNoneAck(ecode);
  123. });
  124. g_cmdScheduler.regCMD("xy_robot_ctrl_factory_reset", "(id)", 1, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  125. int32_t ecode = g_zmodule_device_manager.module_factory_reset(XY_ROBOT_ID);
  126. ack->setNoneAck(ecode);
  127. });
  128. g_cmdScheduler.regCMD("xy_robot_ctrl_flush", "(id)", 1, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  129. int32_t ecode = g_zmodule_device_manager.module_flush_cfg(XY_ROBOT_ID);
  130. ack->setNoneAck(ecode);
  131. });
  132. #if 0
  133. g_cmdScheduler.regCMD("xy_robot_ctrl_force_change_current_pos", "(id,x,y)", 3, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  134. int32_t x = atoi(paraV[1]);
  135. int32_t y = atoi(paraV[2]);
  136. int32_t ecode = g_zmodule_device_manager.motor_set_current_pos_by_change_shift(XY_ROBOT_ID, x, y);
  137. ack->setNoneAck(ecode);
  138. });
  139. #endif
  140. g_cmdScheduler.regCMD("xy_robot_ctrl_get_base_param", "(id)", 1, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) { g_zmodule_device_script_cmder_paser.do_dumpconfig(paramN, paraV, ack); });
  141. g_cmdScheduler.regCMD("xy_robot_ctrl_move_by", "(id,dx,dy,v)", 4, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  142. int32_t dx = atoi(paraV[1]);
  143. int32_t dy = atoi(paraV[2]);
  144. int32_t v = atoi(paraV[3]);
  145. int32_t ecode = g_zmodule_device_manager.xymotor_move_by(XY_ROBOT_ID, dx, dy, v);
  146. ack->setNoneAck(ecode);
  147. });
  148. g_cmdScheduler.regCMD("xy_robot_ctrl_move_to", "(id,x,y,speed)", 4, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  149. int32_t x = atoi(paraV[1]);
  150. int32_t y = atoi(paraV[2]);
  151. int32_t speed = atoi(paraV[3]);
  152. int32_t ecode = g_zmodule_device_manager.xymotor_move_to(XY_ROBOT_ID, x, y, speed);
  153. ack->setNoneAck(ecode);
  154. });
  155. g_cmdScheduler.regCMD("xy_robot_ctrl_move_to_zero", "(id)", 1, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  156. int32_t ecode = g_zmodule_device_manager.xymotor_move_to_zero(XY_ROBOT_ID);
  157. ack->setNoneAck(ecode);
  158. });
  159. g_cmdScheduler.regCMD("xy_robot_ctrl_move_to_zero_with_calibrate", "(id,nowx,nowy)", 3, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  160. int32_t nowx = atoi(paraV[1]);
  161. int32_t nowy = atoi(paraV[2]);
  162. int32_t ecode = g_zmodule_device_manager.xymotor_move_to_zero_and_calculated_shift(XY_ROBOT_ID);
  163. ack->setNoneAck(ecode);
  164. });
  165. g_cmdScheduler.regCMD("xy_robot_ctrl_stop", "(id,stop_type)", 2, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  166. int32_t stop_type = atoi(paraV[1]);
  167. int32_t ecode = g_zmodule_device_manager.module_stop(XY_ROBOT_ID);
  168. ack->setNoneAck(ecode);
  169. });
  170. #if 0
  171. 00102227 INFO [CMD ] step_motor_ctrl_enable (id,en)
  172. 00102251 INFO [CMD ] step_motor_ctrl_get_base_param (id)
  173. 00102277 INFO [CMD ] step_motor_ctrl_move_by (id,dx,speed)
  174. 00102283 INFO [CMD ] step_motor_ctrl_move_to (id,x,speed)
  175. 00102298 INFO [CMD ] step_motor_ctrl_move_to_zero (id)
  176. 00102304 INFO [CMD ] step_motor_ctrl_move_to_zero_with_calibrate (id,x)
  177. 00102311 INFO [CMD ] step_motor_ctrl_read_detailed_status (id)
  178. 00102318 INFO [CMD ] step_motor_ctrl_read_status (id)
  179. 00102330 INFO [CMD ] step_motor_ctrl_rotate (id,speed,lastforms)
  180. 00102362 INFO [CMD ] step_motor_ctrl_stop (id,stop_type)
  181. #endif
  182. g_cmdScheduler.regCMD("step_motor_ctrl_enable", "(id,en)", 2, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  183. int32_t en = atoi(paraV[1]);
  184. int32_t ecode = g_zmodule_device_manager.motor_enable(4, en);
  185. ack->setNoneAck(ecode);
  186. });
  187. g_cmdScheduler.regCMD("step_motor_ctrl_get_base_param", "(id)", 1, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) { //
  188. g_zmodule_device_script_cmder_paser.do_dumpconfig(4);
  189. });
  190. g_cmdScheduler.regCMD("step_motor_ctrl_move_by", "(id,dx,speed)", 3, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  191. int32_t dx = atoi(paraV[1]);
  192. int32_t speed = atoi(paraV[2]);
  193. int32_t ecode = g_zmodule_device_manager.motor_move_by(4, dx, speed, 0);
  194. ack->setNoneAck(ecode);
  195. });
  196. g_cmdScheduler.regCMD("step_motor_ctrl_move_to", "(id,x,speed)", 3, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  197. int32_t x = atoi(paraV[1]);
  198. int32_t speed = atoi(paraV[2]);
  199. int32_t ecode = g_zmodule_device_manager.motor_move_to(4, x, speed, 0);
  200. ack->setNoneAck(ecode);
  201. });
  202. g_cmdScheduler.regCMD("step_motor_ctrl_move_to_zero", "(id)", 1, [](int32_t paramN, const char** paraV, ICmdParserACK* ack) {
  203. int32_t ecode = g_zmodule_device_manager.motor_move_to_zero_backward(4, 0, 0, 0, 0);
  204. ack->setNoneAck(ecode);
  205. });
  206. }