xCore-SDK  0.5.0
xCore SDK C# API
rokae::clr::Cobot类 参考

协作机器人通用接口 更多...

#include <robot_cli.hpp>

类 rokae::clr::Cobot 继承关系图:
rokae::clr::BaseRobot rokae::clr::xMateCr5Robot rokae::clr::xMateErProRobot rokae::clr::xMateRobot

Public 成员函数

void enableDrag (DragOpt::Space space, DragOpt::Type type, [Out] ErrorCode^% ec)
 打开拖动 更多...
 
void enableDrag (DragOpt::Space space, DragOpt::Type type, bool enable_drag_button, [Out] ErrorCode^% ec)
 打开拖动 更多...
 
void disableDrag ([Out] ErrorCode^% ec)
 关闭拖动 更多...
 
void enableCollisionDetection (array< double >^ sensitivity, StopLevel behaviour, double fallback_compliance, [Out] ErrorCode^% ec)
 设置碰撞检测相关参数, 打开碰撞检测功能。 更多...
 
void disableCollisionDetection ([Out] ErrorCode^% ec)
 关闭碰撞检测功能 更多...
 
void calibrateForceSensor (bool all_axes, int axis_index, [Out] ErrorCode^% ec)
 力传感器标定。标定过程需要约100ms, 该函数不会阻塞等待标定完成。 标定前需要通过setToolset()设置正确的负载(Toolset.load), 否则会影响标定结果准确性。 更多...
 
void startRecordPath ([Out] ErrorCode^% ec)
 开始录制路径。录制的时长需要限制在30分钟以内, 此接口不会阻塞等待,录制完毕调用stopRecordPath()来停止录制 更多...
 
void stopRecordPath ([Out] ErrorCode^% ec)
 停止录制路径, 若录制成功(无错误码)则路径数据保存在缓存中 更多...
 
void cancelRecordPath ([Out] ErrorCode^% ec)
 取消录制, 缓存的路径数据将被删除 更多...
 
void saveRecordPath (String^ name, String^ saveAs, [Out] ErrorCode^% ec)
 保存录制好的路径 更多...
 
void replayPath (String^ name, double rate, [Out] ErrorCode^% ec)
 运动指令-路径回放。 和其它运动指令类似,调用replayPath之后,需调用moveStart才会开始运动。 更多...
 
void removePath (String^ name, bool removeAll, [Out] ErrorCode^% ec)
 删除已保存的路径 更多...
 
List< String^> queryPathLists ([Out] ErrorCode^% ec)
 查询已保存的所有路径名称 更多...
 
void setxPanelVout (xPanelOpt::Vout opt, [Out] ErrorCode^% ec)
 设置xPanel对外供电模式。注:仅部分机型支持xPanel功能,不支持的机型会返回错误码 更多...
 
void setxPanelRS485 (xPanelOpt::Vout opt, bool if_rs485, [Out] ErrorCode^% ec)
 使用CR和SR末端的485通信功能,需要修改末端的参数配置,可通过此接口进行参数配置 更多...
 
void XPRWModbusRTUReg (int slave_addr, int fun_cmd, int reg_addr, String^ data_type, int num, array< int >^% data_array, bool if_crc_reverse, [Out] ErrorCode^% ec)
 通过xPanel末端读写modbus寄存器 更多...
 
void XPRWModbusRTUCoil (int slave_addr, int fun_cmd, int coil_addr, int num, array< bool >^% data_array, bool if_crc_reverse, [Out] ErrorCode^% ec)
 通过xPanel末端读写modbus线圈或离散输入 更多...
 
void XPRS485SendData (int send_byte, int rev_byte, array< Byte >^ send_data, array< Byte >^% recv_data, [Out] ErrorCode^% ec)
 通过xPanel末端直接传输RTU协议裸数据 更多...
 
array< bool > getKeypadState ([Out] ErrorCode^% ec)
 获取末端按键状态,不支持的机型会返回错误码。 更多...
 
ForceControl forceControl ()
 力控指令类 更多...
 
- Public 成员函数 继承自 rokae::clr::BaseRobot
virtual ~BaseRobot ()
 Deconstructor
 
void connectToRobot ([Out] ErrorCode^% ec)
 连接到机器人。机器人地址为创建StandardRobot实例时传入的 更多...
 
void connectToRobot (String^ remoteIP)
 建立与机器人的连接。 更多...
 
void connectToRobot (String^ remoteIP, String^ localIP)
 建立与机器人的连接。 更多...
 
void disconnectFromRobot ([Out] ErrorCode^% ec)
 断开与机器人连接。断开前会停止机器人运动, 请注意安全。 更多...
 
Info robotInfo ([Out] ErrorCode^% ec)
 查询机器人基本信息 更多...
 
String sdkVersion ()
 查询xCoreSDK版本 更多...
 
PowerState powerState ([Out] ErrorCode^% ec)
 查询机器人上下电以及急停状态 更多...
 
void setPowerState (Boolean on, [Out] ErrorCode^% ec)
 机器人上下电。注: 只有无外接使能开关或示教器的机器人才能手动模式上电。 更多...
 
OperateMode operateMode ([Out] ErrorCode^% ec)
 查询机器人当前操作模式 更多...
 
void setOperateMode (OperateMode mode, [Out] ErrorCode^% ec)
 切换手自动模式 更多...
 
OperationState operationState ([Out] ErrorCode^% ec)
 查询机器人当前运行状态 (空闲, 运动中, 拖动开启等) 更多...
 
array< double > jointPos ([Out] ErrorCode^% ec)
 机器人当前轴角度 [rad], 机器人本体以及外部轴(若有)。 导轨[m] 更多...
 
array< double > jointVel ([Out] ErrorCode^% ec)
 机器人当前关节速度 [rad/s], 机器人本体以及外部轴(若有)。 导轨[m/s] 更多...
 
array< double > jointTorque ([Out] ErrorCode^% ec)
 关节力传感器数值 [Nm] 更多...
 
array< double > posture (CoordinateType ct, [Out] ErrorCode^% ec)
 获取机器人法兰或末端的当前位姿 更多...
 
CartesianPosition cartPosture (CoordinateType ct, [Out] ErrorCode^% ec)
 获取机器人法兰或末端的当前位姿 更多...
 
array< double > baseFrame ([Out] ErrorCode^% ec)
 读取基坐标系, 相对于世界坐标系 更多...
 
Toolset toolset ([Out] ErrorCode^% ec)
 查询当前工具工件组信息. 更多...
 
void setToolset (Toolset^ toolset, [Out] ErrorCode^% ec)
 设置工具工件组信息。 更多...
 
void setToolset (System::String^ toolName, System::String^ wobjName, [Out] ErrorCode^% ec)
 使用已创建的工具和工件,设置工具工件组信息 更多...
 
void setBaseFrame (Frame^ frame, [Out] ErrorCode^% ec)
 设置基坐标系, 设置后仅保存数值,重启控制器后生效 更多...
 
void setMotionControlMode (MotionControlMode mode, [Out] ErrorCode^% ec)
 设置运动控制模式. 更多...
 
void moveReset ([Out] ErrorCode^% ec)
 运动重置, 清空已发送的运动指令, 清除执行信息。 Robot类在初始化时会调用一次运动重置。RL程序和SDK运动指令切换控制,需要先运动重置。 更多...
 
void stop ([Out] ErrorCode^% ec)
 暂停机器人运动; 暂停后可调用moveStart()继续运动。若需要完全停止,不再执行已添加的指令,可调用moveReset() 更多...
 
void executeCommand (MoveCommand::Type type, List< MoveCommand^>^ cmd, [Out] ErrorCode^% ec)
 执行单条或多条运动指令,调用后机器人立刻开始运动 更多...
 
void moveAppend (MoveCommand::Type type, List< MoveCommand^>^ cmd, System::String^% cmdId, [Out] ErrorCode^% ec)
 添加单条或多条运动指令, 添加后调用moveStart()开始运动 更多...
 
void moveAppend (MoveCommand::Type type, MoveCommand^ cmd, System::String^% cmdId, [Out] ErrorCode^% ec)
 下发单条运动指令 更多...
 
void setDefaultSpeed (int speed, [Out] ErrorCode^% ec)
 设定默认运动速度,初始值为100。该数值表示末端最大线速度(单位mm/s), 自动计算对应关节速度。 关节速度百分比划分为5个的范围:

  • < 100 10%
  • 100 ~ 200 30%
  • 200 ~ 500 50%
  • 500 ~ 800 80%
  • > 800 100%

空间旋转速度为200°/s 更多...

 
void setDefaultZone (int zone, [Out] ErrorCode^% ec)
 设定默认转弯区。初始值为为0 (fine, 无转弯区)。该数值表示运动最大转弯区半径(单位:mm), 自动计算转弯百分比 转弯百分比划分4个范围:

  • < 1 0 (fine)
  • 1 ~ 20 10 %
  • 20 ~ 60 30 %
  • > 60 100 %
更多...
 
void setDefaultConfOpt (bool forced, [Out] ErrorCode^% ec)
 设置是否使用轴配置数据(confData)计算逆解。初始值为false 更多...
 
void moveStart ([Out] ErrorCode^% ec)
 开始/继续运动 更多...
 
void setMaxCacheSize (int number, [Out] ErrorCode^% ec)
 设置最大缓存指令个数,指发送到控制器待规划的路径点个数,允许的范围[1,300],初始值为30。 更多...
 
void adjustSpeedOnline (double scale, [Out] ErrorCode^% ec)
 动态调整机器人运动速率,非实时模式时生效。 更多...
 
void getAcceleration (double% acc, double% jerk, [Out] ErrorCode^% ec)
 读取当前加/减速度和加加速度 更多...
 
void adjustAcceleration (double acc, double jerk, [Out] ErrorCode^% ec)
 调节运动加/减速度和加加速度。如果在机器人运动中调用,当前正在执行的指令不生效,下一条指令生效 更多...
 
EventInfo queryEventInfo (Event eventType, [Out] ErrorCode^% ec)
 查询事件信息。 更多...
 
void setEventWatcher (Event eventType, EventCallbackDelegate^ callback, [Out] ErrorCode^% ec)
 设置接收事件的回调函数。 更多...
 
void startJog (JogSpace space, double rate, double step, unsigned index, bool direction, [Out] ErrorCode^% ec)
 开始jog机器人,需要切换到手动操作模式。调用此接口并且机器人开始运动后,无论机器人是否已经自行停止,都必须调用stop()来结束jog操作,否则机器人会一直处于jog的运行状态。 更多...
 
void clearServoAlarm ([Out] ErrorCode^% ec)
 清除伺服报警 更多...
 
List< LogInfo^> queryControllerLog (unsigned count, LogInfo::Level level, [Out] ErrorCode^% ec)
 查询控制器最新的日志 更多...
 
void setDI (unsigned int board, unsigned int port, bool state, [Out] ErrorCode^% ec)
 设置数字量输入信号,仅当输入仿真模式打开时可以设置(见setSimulationMode()) 更多...
 
bool getDI (unsigned int board, unsigned int port, [Out] ErrorCode^% ec)
 查询数字量输入信号值 更多...
 
void setDO (unsigned int board, unsigned int port, bool state, [Out] ErrorCode^% ec)
 设置数字量输出信号值 更多...
 
bool getDO (unsigned int board, unsigned int port, [Out] ErrorCode^% ec)
 查询数字输出量信号值 更多...
 
double getAI (unsigned board, unsigned port, [Out] ErrorCode^% ec)
 读取模拟量输入信号值 更多...
 
void setAO (unsigned board, unsigned port, double value, [Out] ErrorCode^% ec)
 设置模拟量输出信号 更多...
 
void setSimulationMode (bool state, [Out] ErrorCode^% ec)
 设置输入仿真模式 更多...
 
void readRegister (System::String^ name, List< bool >^% value, [Out] ErrorCode^% ec)
 读取bit/bool类型寄存器数组。 更多...
 
void readRegister (System::String^ name, List< int >^% value, [Out] ErrorCode^% ec)
 读取int16/int32类型寄存器数组。 更多...
 
void readRegister (System::String^ name, List< float >^% value, [Out] ErrorCode^% ec)
 读取float类型寄存器数组。 更多...
 
void readRegister (System::String^ name, unsigned index, bool% value, [Out] ErrorCode^% ec)
 读取bit/bool类型寄存器值。可读取单个寄存器,或按索引读取寄存器数组 更多...
 
void readRegister (System::String^ name, unsigned index, int% value, [Out] ErrorCode^% ec)
 读取int16/int32类型寄存器值。可读取单个寄存器,或按索引读取寄存器数组 更多...
 
void readRegister (System::String^ name, unsigned index, float% value, [Out] ErrorCode^% ec)
 读取float类型寄存器值。可读取单个寄存器,或按索引读取寄存器数组 更多...
 
void writeRegister (System::String^ name, unsigned index, bool value, [Out] ErrorCode^% ec)
 写bool/bit类型寄存器值。可写入单个寄存器,或按索引写入寄存器数组中某一元素。 更多...
 
void writeRegister (System::String^ name, unsigned index, Int32 value, [Out] ErrorCode^% ec)
 写byte/int16/int32寄存器值。可写入单个寄存器,或按索引写入寄存器数组中某一元素。 更多...
 
void writeRegister (System::String^ name, unsigned index, float value, [Out] ErrorCode^% ec)
 写float类型寄存器值。可写入单个寄存器,或按索引写入寄存器数组中某一元素。 更多...
 
void writeRegister (System::String^ name, unsigned index, array< bool >^ value, [Out] ErrorCode^% ec)
 写bool/bit类型寄存器数组 更多...
 
void writeRegister (System::String^ name, unsigned index, array< int >^ value, [Out] ErrorCode^% ec)
 写int16/int32类型寄存器数组。 更多...
 
void writeRegister (System::String^ name, unsigned index, array< float >^ value, [Out] ErrorCode^% ec)
 写float类型寄存器数组。 更多...
 
List< RLProjectInfo^> projectsInfo ([Out] ErrorCode^% ec)
 查询工控机中RL工程名称及任务 更多...
 
void loadProject (String^ name, System::Collections::Generic::List< System::String^>^ tasks, [Out] ErrorCode^% ec)
 加载工程 更多...
 
void ppToMain ([Out] ErrorCode^% ec)
 程序指针跳转到main。调用后,等待控制器解析完工程后返回,阻塞时间视工程大小而定,超时时间设定为10秒。 更多...
 
void runProject ([Out] ErrorCode^% ec)
 开始运行当前加载的工程 更多...
 
void pauseProject ([Out] ErrorCode^% ec)
 暂停运行工程 更多...
 
void setProjectRunningOpt (double rate, bool loop, [Out] ErrorCode^% ec)
 更改工程的运行速度和循环模式 更多...
 
List< WorkToolInfo^> toolsInfo ([Out] ErrorCode^% ec)
 查询当前加载工程的工具信息 更多...
 
List< WorkToolInfo^> wobjsInfo ([Out] ErrorCode^% ec)
 查询当前加载工程的工件信息 更多...
 
void setRailParameter (System::String^ name, Frame^ value, [Out] ErrorCode^% ec)
 设置导轨基坐标系 更多...
 
void setRailParameter (System::String^ name, System::String^ value, [Out] ErrorCode^% ec)
 设置导轨名称 更多...
 
void setRailParameter (System::String^ name, double value, [Out] ErrorCode^% ec)
 设置导轨参数 更多...
 
void setRailParameter (System::String^ name, bool value, [Out] ErrorCode^% ec)
 打开关闭导轨 更多...
 
void setRailParameter (System::String^ name, array< double >^ value, [Out] ErrorCode^% ec)
 设置导轨软限位和运动范围 更多...
 
void setRailParameter (System::String^ name, int value, [Out] ErrorCode^% ec)
 设置导轨参数 更多...
 
void getRailParameter (System::String^ name, bool% value, [Out] ErrorCode^% ec)
 读取导轨是否打开 更多...
 
void getRailParameter (System::String^ name, String^% value, [Out] ErrorCode^% ec)
 读取导轨名称 更多...
 
void getRailParameter (System::String^ name, Frame^% value, [Out] ErrorCode^% ec)
 读取导轨基座标系 更多...
 
void getRailParameter (System::String^ name, int% value, [Out] ErrorCode^% ec)
 读取导轨参数 更多...
 
void getRailParameter (System::String^ name, double% value, [Out] ErrorCode^% ec)
 读取导轨参数 更多...
 
void getRailParameter (System::String^ name, array< double >^% value, [Out] ErrorCode^% ec)
 读取导轨软限位和运动范围 更多...
 
int getStateData (String^ name, array< double >^% data)
 读取机器人状态数据,注意传入的data类型要和数据类型一致。

支持的数据名称及数组长度 关节角度[rad]"q_m" | DoF 关节速度[rad/s]"dq_m" | DoF 关节力矩[Nm]"tau_m" | DoF 电机位置"theta_m" | DoF 电机位置微分"theta_vel_m" | DoF 电机转矩"motor_tau" | DoF 末端位姿, 相对于外部坐标系 [X,Y,Z,Rx,Ry,Rz]"pos_abc_m" | 6 末端位姿, 相对于外部坐标系, 行优先齐次变换矩阵"pos_m" | 16 外部轴角度[rad] 导轨[m]"ex_q_m" | 6 外部轴速度[rad/s] 导轨[m/s]"ex_dq_m" | 6 外部轴电机位置"ex_motor_m" | 6 更多...

 
int getStateData (String^ name, UInt64% data)
 读取机器人状态数据

支持的数据名称 时间戳,精确到微秒"ts" 更多...

 
int getStateData (String^ name, double% data)
 读取机器人状态数据

支持的数据名称 臂角[rad]"psi_m" 更多...

 
void stopReceiveRobotState ()
 停止接收实时状态数据,同时控制器停止发送。可用于重新设置要接收的状态数据。
 
unsigned updateRobotState (int timeout_ms)
 接收一次机器人状态数据,在每周期读取数据前,需调用此函数。阻塞等待收到新数据,或超时返回。 建议按照设定的发送频率来调用,以获取最新的数据 更多...
 
void configNtp (System::String^ server_ip, [Out] ErrorCode^% ec)
 配置NTP 更多...
 
void syncTimeWithServer ([Out] ErrorCode^% ec)
 手动同步一次时间,远端IP是通过configNtp配置的。耗时几秒钟,阻塞等待同步完成,接口预设的超时时间是12秒 更多...
 
array< double > checkPath (CartesianPosition^ start, array< double >^ start_joint, CartesianPosition^ target, [Out] ErrorCode^% ec)
 检验直线轨迹是否可达。支持导轨,返回的目标轴角为轴数+外部轴数 更多...
 
int checkPath (array< double >^ start_joint, array< CartesianPosition^>^ targets, array< double >^% target_joint_calculated, [Out] ErrorCode^% ec)
 校验多个直线轨迹 更多...
 
array< double > checkPath (CartesianPosition^ start, array< double >^ start_joint, CartesianPosition^ aux, CartesianPosition^ target, [Out] ErrorCode^% ec)
 检验圆弧轨迹是否可达 更多...
 
array< double > checkPath (CartesianPosition^ start, array< double >^ start_joint, CartesianPosition^ aux1, CartesianPosition^ aux2, double angle, double rot_type, [Out] ErrorCode^% ec)
 检验全圆轨迹是否可达 更多...
 
void recoverState (int item, [Out] ErrorCode^% ec)
 根据选项恢复机器人状态 更多...
 
array< double > calcIk (CartesianPosition^ posture, [Out] ErrorCode^% ec)
 根据位姿计算逆解 更多...
 
array< double > calcIk (CartesianPosition^ posture, Toolset^ toolset, [Out] ErrorCode^% ec)
 根据位姿计算给定工具工件坐标系下逆解 更多...
 
CartesianPosition calcFk (array< double >^ joints, [Out] ErrorCode^% ec)
 根据轴角度计算正解 更多...
 
CartesianPosition calcFk (array< double >^ joints, Toolset^ toolset, [Out] ErrorCode^% ec)
 根据轴角度计算给定工具工件坐标系下正解 更多...
 
FrameCalibrationResult calibrateFrame (FrameType type, List< array< double >^>^ points, bool is_held, array< double >^ base_aux, [Out] ErrorCode^% ec)
 坐标系标定 (N点标定). 更多...
 
bool getSoftLimit (array< double, 2 >^% limits, [Out] ErrorCode^% ec)
 获取当前软限位数值 更多...
 
void setSoftLimit (bool enable, array< double, 2 >^ limits, [Out] ErrorCode^% ec)
 设置软限位。软限位设定要求:

  • 打开软限位时,机械臂应下电且处于手动模式
  • 软限位不能超过机械硬限位
  • 机械臂当前各轴角度应在设定的限位范围内
更多...
 
void startReceiveRobotState (int interval, array< System::String^>^ fields)
 让机器人控制器开始发送实时状态数据。阻塞等待收到第一帧消息,超时时间为3秒 更多...
 

Protected 属性

rokae::BaseCobot * robot
 
- Protected 属性 继承自 rokae::clr::BaseRobot
rokae::BaseRobot * robot
 
rokae::StandardRobot * ir6
 
rokae::PCB3Robot * ir3
 
rokae::PCB4Robot * ir4
 
rokae::xMateCr5Robot * cobot5
 
rokae::xMateRobot * cobot6
 
rokae::xMateErProRobot * cobot7
 
rokae::Model_T< 3 > * model3
 
rokae::Model_T< 4 > * model4
 
rokae::Model_T< 5 > * model5
 
rokae::Model_T< 6 > * model6
 
rokae::Model_T< 7 > * model7
 
EventCallbackNativeDelegate _moveNativeDelegate
 
EventCallbackNativeDelegate _safetyNativeDelegate
 
EventCallbackNativeDelegate _rlExecutionNativeDelegate
 

额外继承的成员函数

- Protected 成员函数 继承自 rokae::clr::BaseRobot
void _moveEventCallback (const std::unordered_map< std::string, std::any > &info)
 
void _safetyEventCallback (const std::unordered_map< std::string, std::any > &info)
 
void _rlExecutionEventCallback (const std::unordered_map< std::string, std::any > &info)
 
- 静态 Protected 属性 继承自 rokae::clr::BaseRobot
static EventCallbackDelegate _moveManagedDelegate
 
static EventCallbackDelegate _safetyManagedDelegate
 
static EventCallbackDelegate _rlExecutionManagedDelegate
 

详细描述

协作机器人通用接口

在文件 robot_cli.hpp1084 行定义.

成员函数说明

◆ calibrateForceSensor()

void rokae::clr::Cobot::calibrateForceSensor ( bool  all_axes,
int  axis_index,
[Out] ErrorCode^%  ec 
)

力传感器标定。标定过程需要约100ms, 该函数不会阻塞等待标定完成。 标定前需要通过setToolset()设置正确的负载(Toolset.load), 否则会影响标定结果准确性。

参数
all_axestrue - 标定所有轴 | false - 单轴标定
axis_index轴下标, 范围[0, 6), 仅当单轴标定时生效
ec错误码

◆ cancelRecordPath()

void rokae::clr::Cobot::cancelRecordPath ( [Out] ErrorCode^%  ec)

取消录制, 缓存的路径数据将被删除

参数
ec错误码

◆ disableCollisionDetection()

void rokae::clr::Cobot::disableCollisionDetection ( [Out] ErrorCode^%  ec)

关闭碰撞检测功能

参数
ec错误码

◆ disableDrag()

void rokae::clr::Cobot::disableDrag ( [Out] ErrorCode^%  ec)

关闭拖动

参数
ec错误码

◆ enableCollisionDetection()

void rokae::clr::Cobot::enableCollisionDetection ( array< double >^  sensitivity,
StopLevel  behaviour,
double  fallback_compliance,
[Out] ErrorCode^%  ec 
)

设置碰撞检测相关参数, 打开碰撞检测功能。

参数
sensitivity碰撞检测灵敏度,范围0.01-2.0
behaviour碰撞后机器人行为, 支持stop1(安全停止, stop0和stop1处理方式相同), stop2(触发暂停), suppleStop(柔顺停止)
fallback_compliance根据碰撞后机器人行为,参数含义分别是
  • 安全停止,触发暂停碰撞后回退距离,单位: 米
  • 柔顺停止柔顺度,范围 [0.0, 1.0]
ec错误码
异常
System::NullReferenceExceptionRobot类未构造

◆ enableDrag() [1/2]

void rokae::clr::Cobot::enableDrag ( DragOpt::Space  space,
DragOpt::Type  type,
[Out] ErrorCode^%  ec 
)

打开拖动

参数
space拖动空间。轴空间拖动仅支持自由拖拽类型
type拖动类型
ec错误码

◆ enableDrag() [2/2]

void rokae::clr::Cobot::enableDrag ( DragOpt::Space  space,
DragOpt::Type  type,
bool  enable_drag_button,
[Out] ErrorCode^%  ec 
)

打开拖动

参数
space拖动空间。轴空间拖动仅支持自由拖拽类型
type拖动类型
enable_drag_buttonTrue - 打开拖动功能之后可以直接拖动机器人,不需要按住末端按键
ec错误码

◆ forceControl()

ForceControl rokae::clr::Cobot::forceControl ( )

力控指令类

返回
ForceControl
异常
System::NullReferenceExceptionRobot类未构造

◆ getKeypadState()

array< bool > rokae::clr::Cobot::getKeypadState ( [Out] ErrorCode^%  ec)

获取末端按键状态,不支持的机型会返回错误码。

参数
ec错误码
返回
末端按键的状态, 长度为7的数组。 末端按键编号见《xCore机器人控制系统使用手册》末端把手的图示

◆ queryPathLists()

List< String^> rokae::clr::Cobot::queryPathLists ( [Out] ErrorCode^%  ec)

查询已保存的所有路径名称

参数
ec错误码
返回
名称列表, 若没有路径则返回空列表

◆ removePath()

void rokae::clr::Cobot::removePath ( String^  name,
bool  removeAll,
[Out] ErrorCode^%  ec 
)

删除已保存的路径

参数
name要删除的路径名称
removeAll是否删除所有路径
ec错误码。若路径不存在,错误码不会被置位

◆ replayPath()

void rokae::clr::Cobot::replayPath ( String^  name,
double  rate,
[Out] ErrorCode^%  ec 
)

运动指令-路径回放。 和其它运动指令类似,调用replayPath之后,需调用moveStart才会开始运动。

参数
name要回放的路径名称
rate回放速率, 应小于3.0, 1为路径原始速率。注意当速率大于1时,可能产生驱动器无法跟随错误
ec错误码

◆ saveRecordPath()

void rokae::clr::Cobot::saveRecordPath ( String^  name,
String^  saveAs,
[Out] ErrorCode^%  ec 
)

保存录制好的路径

参数
name路径名称
saveAs重命名,可传入空字符串。如果已录制好一条路径但没有保存,则用该名字保存路径。如果没有未保存的路径,则将已保存的名为"name"的路径重命名为"saveAs"
ec错误码

◆ setxPanelRS485()

void rokae::clr::Cobot::setxPanelRS485 ( xPanelOpt::Vout  opt,
bool  if_rs485,
[Out] ErrorCode^%  ec 
)

使用CR和SR末端的485通信功能,需要修改末端的参数配置,可通过此接口进行参数配置

参数
opt对外供电模式,0:不输出,1:保留,2:12v,3:24v
if_rs485接口工作模式,是否打开末端485通信
ec错误码

◆ setxPanelVout()

void rokae::clr::Cobot::setxPanelVout ( xPanelOpt::Vout  opt,
[Out] ErrorCode^%  ec 
)

设置xPanel对外供电模式。注:仅部分机型支持xPanel功能,不支持的机型会返回错误码

参数
opt模式
ec错误码

◆ startRecordPath()

void rokae::clr::Cobot::startRecordPath ( [Out] ErrorCode^%  ec)

开始录制路径。录制的时长需要限制在30分钟以内, 此接口不会阻塞等待,录制完毕调用stopRecordPath()来停止录制

参数
ec错误码

◆ stopRecordPath()

void rokae::clr::Cobot::stopRecordPath ( [Out] ErrorCode^%  ec)

停止录制路径, 若录制成功(无错误码)则路径数据保存在缓存中

参数
ec错误码

◆ XPRS485SendData()

void rokae::clr::Cobot::XPRS485SendData ( int  send_byte,
int  rev_byte,
array< Byte >^  send_data,
array< Byte >^%  recv_data,
[Out] ErrorCode^%  ec 
)

通过xPanel末端直接传输RTU协议裸数据

参数
send_byte发送字节长度 0-16
rev_byte接收字节长度 0-16
send_data发送字节数据 数组长度需要和send_byte 参数一致
recv_data接收字节数据 数组长度需要和rev_byte 参数一致
ec错误码

◆ XPRWModbusRTUCoil()

void rokae::clr::Cobot::XPRWModbusRTUCoil ( int  slave_addr,
int  fun_cmd,
int  coil_addr,
int  num,
array< bool >^%  data_array,
bool  if_crc_reverse,
[Out] ErrorCode^%  ec 
)

通过xPanel末端读写modbus线圈或离散输入

参数
slave_addr设备地址 0-65535
fun_cmd功能码 0x01 0x02 0x05 0x0F
coil_addr线圈或离散输入寄存器地址 0-65535
num一次连续读写线圈离散输入的个数(0-48),功能码0x05时,此值无效
data_arraydata_array 发送或接收数据的数组,非const,功能码为0x05时,只使用此数组的数据[0],此时num的值无效,除了0x05功能码,大小需要与num匹配
if_crc_reverse是否改变CRC校验高低位,默认false,少数厂家末端工具需要反转
ec错误码

◆ XPRWModbusRTUReg()

void rokae::clr::Cobot::XPRWModbusRTUReg ( int  slave_addr,
int  fun_cmd,
int  reg_addr,
String^  data_type,
int  num,
array< int >^%  data_array,
bool  if_crc_reverse,
[Out] ErrorCode^%  ec 
)

通过xPanel末端读写modbus寄存器

参数
slave_addr设备地址 0-65535
fun_cmd功能码 0x03 0x04 0x06 0x10
reg_addr寄存器地址 0-65535
data_type支持的数据类型 int32、int16、uint32、uint16
num一次连续操作寄存器的个数 0-3,类型为int16/uint16时,最大为3;类型为int32/uint32、float时,最大为1,功能码为0x06时,此参数无效
data_array发送或接收数据的数组,非const,功能码为0x06时,只使用此数组的数据[0],此时num的值无效,除了0x06功能码,大小需要与num匹配
if_crc_reverse是否改变CRC校验高低位,默认使用false,少数厂家末端工具需要反转
ec错误码

类成员变量说明

◆ robot

rokae::BaseCobot* rokae::clr::Cobot::robot
protected

在文件 robot_cli.hpp1086 行定义.


该类的文档由以下文件生成: