FANUC(发那科)接口程序指令说明

您正在查看旧版本的文档。点击页面右上角可切换到最新版本的文档。

FANUC 机器人程序调用说明:

  1. 程序的形参列表中各个参数之间以逗号分隔;

  2. 每个形参变量都定义为局部变量,只在程序中有效;

  3. 程序的形参列表支持定义输入参数和输出参数。

标准接口程序指令如下。

初始化通信参数指令

该指令用于设置 TCP/IP 通信的客户端口号,IP 地址,服务端口号,以及通信超时等待时间。

程序

MM_INIT_SKT(C_Tag, Ip_Addr, Svr_Port, Time_Out)

参数

参数 描述

输入参数

C_Tag

机器人端口号字符串,选择端口号 1~8 中的一个即可。

Ip_Addr

工控机 IP 字符串。

Svr_Port

服务端口号,默认为 50000。

Time_Out

等待时间,单位为 min。

示例

CALL MM_INIT_SKT('1','192.168.1.20',50000,5)

该实例程序指定客户端口号为 1,工控机 IP 地址为:192.168.1.20,服务端口号为 50000,超时时间为 5min。

启动 Mech-Vision 工程

该指令用于触发 Mech-Vision 工程的运行,执行相机拍照和视觉处理。用于只使用 Mech-Vision 而不使用 Mech-Viz 的场景。

程序

MM_START_VIS(Job,Pos_Num_Need,SendPos_Type,Pr_Num)

参数

参数 描述

输入参数

Job

Mech-Vision 工程编号,可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

Pos_Num_Need

预期视觉点数量,即期望从 Mech-Vision 得到的视觉点数量。可设置范围 [0~20],0 表示获取所有。

SendPos_Type

机器人位姿类型,该参数指定真实机器人的位姿将以何种形式传入 Mech-Vision。参数范围:[0~3]。

  • 0:该指令不需向视觉系统传入机器人位姿。若工程为 Eye To Hand 模式,则拍照与机器人位姿无关,Mech-Vision 不需要机器人的位姿。

  • 1:该指令以“机器人当前关节角+当前法兰”形式向视觉系统传入机器人位姿。若工程为 Eye In Hand 模式,则推荐使用该参数。在使用时,Mech-Vision 工程中存在的“路径规划”步骤将使用机器人发送关节角。如果法兰位姿为全零,则忽略法兰数据。

  • 2:该指令以当前法兰位姿形式向视觉系统传入机器人位姿,适用于工程为 Eye In Hand 模式,且机器人无关节角数据,仅有法兰位姿数据(如桁架机器人)的场景中。

  • 3:该指令以预定义关节角(读取用户设置的关节角变量)形式向视觉系统传入机器人位姿。若工程为 Eye To Hand 模式,则推荐使用该参数。在使用时,Mech-Vision 工程中存在的“路径规划”步骤将使用机器人发送的关节角作为初始位姿。

Pr_Num

PR 寄存器号,用于保存机器人预定义的关节角数据(此时将 PR 寄存器的数据形式改为关节),仅当 SendPos_Type=3 时才会使用此寄存器内的关节角数据。

示例

CALL MM_START_VIS(1,1,1,60)

该示例触发 Mech-Vision 工程 1 的运行,希望 Mech-Vision 工程 1 返回 1 个视觉结果,机器人将当前关节角和法兰数据传入 Mech-Vision。

获取视觉目标点

该指令用于启动 Mech-Vision 工程之后,获取视觉识别结果。用于只使用 Mech-Vision 而不使用 Mech-Viz 的场景。

程序

MM_GET_VIS(Job,Reg_Pos_Num,Reg_Status)

参数

参数 描述

输入参数

Job

Mech-Vision 工程编号,可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

输出参数

Reg_Pos_Num

R 寄存器号,用于保存返回的位姿数量,取值范围为 1~20。

Reg_Status

R 寄存器号,用于保存状态码,具体可参考《标准接口状态码及错误排查》。

示例

CALL MM_GET_VIS(1,51,52)

该示例用于获取 Mech-Vision 工程 1 的视觉结果。返回的视觉点数量保存在寄存器 R[51] 里,指令执行的状态码保存在寄存器 R[52] 里。

启动 Mech-Viz 工程

该指令用于启动 Mech-Viz 工程,调用相应的 Mech-Vision 工程,并规划抓取路径。用于既有 Mech-Vision 又有 Mech-Viz 的场景。

程序

MM_START_VIZ(SendPos_Type,Pr_Num)

参数

参数 描述

输入参数

SendPos_Type

机器人的位姿类型。参数范围:[0~2]。

  • 0:无需向 Mech-Viz 传入机器人位姿,Mech-Viz 软件中仿真机器人将会从关节角 [0,0,0,0,0,0] 位置开始,运动到第一个路径点。

  • 1:将机器人的当前关节角和法兰位姿传入 Mech-Viz,Mech-Viz 软件中仿真机器人将会从当前机器人关节角位置开始,运动到第一个路径点。

  • 2:将机器人的一个预定义关节角传入 Mech-Viz,Mech-Viz 软件中仿真机器人将会从当前机器人预定义关节角的位置开始,运动到第一个路径点。

Pr_Num

PR 寄存器号,用于保存机器人预定义的关节角数据(此时将 PR 寄存器的数据形式改为关节),仅当 SendPos_Type=2 时才会使用此寄存器内的关节角数据。

示例

CALL MM_START_VIZ(1,60)

该示例触发 Mech-Viz 工程运行,将当前机器人的关节角和法兰位姿传入 Mech-Viz。

获取 Mech-Viz 数据

用于获取Mech-Viz工程规划的抓取路径。

程序

MM_GET_VIZ(Jps_Pos, Reg_Pos_Num, Reg_VPos_Num, Reg_Status)

参数

参数 描述

输入参数

Jps_Pos

要获取的路径上点的位姿类型。
1:Mech-Viz 返回的位姿类型为机器人关节角。
2:Mech-Viz 返回的位姿类型为机器人 TCP。

输出参数

Reg_Pos_Num

R 寄存器号,用于保存接收到的位姿数量,Pose 点数量为 1~20。

Reg_VPos_Num

R 寄存器号,用于保存第一个视觉移动在路径中的位置编号。
例如路径是:移动 -1,移动 -2,视觉移动 -1,移动 -3,则视觉移动的位置是 3。若路径中无视觉移动,则返回值为 0。

Reg_Status

R 寄存器号,用于保存状态码,具体可参考《标准接口状态码及错误排查》。

示例

CALL MM_GET_VIZ(2,51,52,53)

该示例用于接收 Mech-Viz 返回的机器人移动路径,移动点数据类型为 TCP,位姿的数量保存在寄存器 R[51] 中,视觉移动点在路径中的编号保存在寄存器 R[52] 中,指令执行的状态码保存在寄存器 R[53] 中。

获取视觉点坐标值

用于将 Mech-Vision 返回的视觉结果,或 Mech-Viz 返回的移动路径里的某个 TCP 数据,转存到指定位置变量中。

程序

MM_GET_POS(Serial, Pr_Num, Reg_Label, Reg_Speed)

参数

参数 描述

输入参数

Serial

指定要转存的是第几个位姿点。

输出参数

Pr_Num

PR 寄存器号,用于保存指定接收的位姿数据。

Reg_Label

R 寄存器号,用于保存和指定位姿数据相对应的标签数据。

Reg_Speed

R 寄存器号,用于保存和指定位姿数据相对应的移动速度。

示例

CALL MM_GET_POS(1,60,61,62)

该示例用于将收到的第一个位姿点保存到位置寄存器 PR[60] 中,将标签保存到寄存器 R[61] 中,将移动速度保存到寄存器 R[62] 中。

获取视觉点关节角(使用 Mech-Viz 软件规划时有效)

用于将 Mech-Vision 返回的视觉结果或 Mech-Viz 返回的移动路径里的某个 JPS 关节角数据转存到指定位置变量中。用于 Mech-Viz 规划时有效。

程序

MM_GET_JPS(Serial, Pr_Num, Reg_Label, Reg_Speed)

参数

参数 描述

输入参数

Serial

指定要转存的是第几个位姿点。

输出参数

Pr_Num

PR 寄存器号,用于保存指定的关节角数据。

Reg_Label

R 寄存器号,用于保存和指定位姿数据相对应的标签数据。

Reg_Speed

R 寄存器号,用于保存和指定位姿数据相对应的移动速度。

示例

CALL MM_GET_JPS(1,60,61,62)

该示例用于将收到的第一个位姿点保存到位置变量 PR[60] 中,将标签保存到变量 R[61] 中,将移动速度保存到变量 R[62] 中。

切换 Mech-Vision 配方

Mech-Vision 的配方功能,用于不同工件识别时,修改 Mech-Vision 工程各步骤的属性参数,包括图像匹配模板,ROI,置信阈值等。该指令需要在 MM_START_VIS 程序之前使用。

程序

MM_SET_MOD(Job, Model_Num)

参数

参数 描述

输入参数

Job

Mech-Vision 工程编号,可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

Model_Num

Mech-Vision 工程中配方模板的编号。编号范围[1~99]。

示例

CALL MM_SET_MOD(2,2)

该示例会将 Mech-Vision 工程 2 的配方切换成配方 2。

选择 Mech-Viz 分支

用于 Mech-Viz 工程中有分支(按服务消息)步骤时,控制 Mech-Viz 工程中的分支步骤走指定的出口。在调用该指令之前,需要先调用 MM_START_VIZ 。Mech-Viz 运行到分支步骤会等待 MM_SET_BCH 发送该分支的分支出口。

程序

MM_SET_BCH(Branch_Num, Export_Num)

参数

参数 描述

输入参数

Branch_Num

分支步骤编号,该参数应为正整数,即消息分支的步骤编号。步骤编号可在步骤参数中读取。

Export_Num

给定分支的出口号,Mech-Viz 工程将沿该出口继续执行。参数范围[1-99] 。

示例

CALL MM_SET_BCH(1,3)

该示例会指定 Mech-Viz 工程执行遇到分支名称为 1 的步骤,走第 3 出口。

设置移动索引

该指令用于设定Mech-Viz步骤的当前索引参数值。带有该参数的步骤包括“按序列移动”、“按阵列移动”、“自定义垛型”、“预设垛型”等。在调用该指令之前,需要先执行 MM_START_VIZ

程序

MM_SET_IDX(Skill_Num, Index_Num)

参数

参数 描述

输入参数

Skill_Num

移动索引步骤编号,该参数应为正整数。步骤编号可在步骤参数中读取。

Index_Num

下次执行此步骤时应设置的索引值。

发送该指令时,Mech-Viz 中的当前索引值将变为该参数值减 1。

当 Mech-Viz 工程运行到该指令指定的步骤时,Mech-Viz 中的当前索引值将增加 1,成为该参数的值。

示例

CALL MM_SET_IDX(2,10)

该示例设置 Mech-Viz 工程中的步骤名称 “2” 的当前索引值为 9。

获取软件状态

用于获取 Mech-Vision,Mech-Viz,Mech-Center 的软件运行状态。目前只支持检测 Mech-Vision 是否注册就绪。

程序

MM_GET_STAT(MM_Status)

参数

参数 描述

输出参数

MM_Status

R 寄存器号,用于保存指令状态码,具体可参考《标准接口状态码及错误排查》。

示例

CALL MM_GET_STAT(70)

该示例将检查系统状态的状态码保存到寄存器 R[70] 中。

向 Mech-Vision 传入物体尺寸

Mech-Vision 工程中动态传入物体尺寸。需要在执行 MM_START_VIS 之前调用。

程序

MM_SET_BS(Job, Lenght, Width, Height)

参数

参数 描述

输入参数

Job

Mech-Vision 工程编号,可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

Lenght

箱子长度,单位 mm(浮点数)。

Width

箱子宽度,单位 mm(浮点数)。

Height

箱子高度,单位 mm(浮点数)。

示例

CALL MM_SET_BS(1,11.0,12.0,13.0)

该示例将设置 Mech-Vision 工程中的读取物体尺寸步骤的物体尺寸为 11 × 12 × 13mm。

获取吸盘DO信号

该指令用于获取Mech-Vision或Mech-Viz规划的吸盘DO信号。机器人通过MM_SET_DL将获取的吸盘DO信号作用于末端工具。

程序

MM_GET_DL(Resource)

参数

参数 描述

输入参数

Resource

该参数指定吸盘DO信号的来源。

  • 0:从Mech-Viz获取吸盘DO信号。

  • 正整数:从Mech-Vision获取吸盘DO信号。此处设置的正整数就是Mech-Vision工程编号。

示例

CALL MM_GET_DL(0)

该示例表示将从Mech-Viz获取的DO信号列表保存到Do_Port[i]数组内。

设置吸盘DO信号

该指令用于将Mech-Vision或Mech-Viz软件返回的DO列表设置到通用输出信号中。

该指令需在 MM_GET_DL 之后被调用。

程序

MM_SET_DL

示例

CALL MM_GET_DL(0)

CALL MM_SET_DL

该示例表示将从Mech-Viz获取的DO信号列表保存到Do_Port[i]数组内,然后将Do_Port[i]值写入到相应的DO信号里。

标定

该程序用于相机外参的自动标定。该程序配合 Mech-Vision 的相机标定工具,可以实现标定过程全自动。具体可以参见标定操作流程。

程序

MM_CALIB(Move_Type, PosJps, WaitTime, AxisNum, AxisVal, Reg_CalibPos)

参数

参数 描述

输入参数

Move_Type

移动方式
1:MoveL
2:MoveJ

PosJps

使用坐标点位或关节角数据
1-坐标点
2-关节角

WaitTime

机器人移动到标定点后的等待时间(防止机器人发生抖动);默认为 2 秒;单位为 s(秒)

AxisNum

机器人轴数

AxisVal

外部轴数据(当有 7 轴时),没有 7 轴写 0;mm(浮点数)

Reg_CalibPos

MM_AUTO_CALIB 中使用位置的寄存器号;默认占用 PR[100]

示例

CALL MM_CALIB(2,1,2,6,0,100)

该示例执行标定流程,机器人通过走关节的形式进行标定,接收的点位使用坐标点的形式,机器人移动到标定点后的等待时间为 2 秒,没有外部轴,使用位置寄存器 PR[100] 存储接收点位的值。

获取 Mech-Vision 的通知消息

该指令用于获取 Mech-Vision 中“通知”步骤的消息,注意需要与 启动 Mech-Vision 工程 或 启动 启动 Mech-Viz 工程 一同使用才能有效。

Mech-Vision 工程中“通知”步骤的参数设置要求如下:

  • “服务名称”参数值固定为 Standard Interface Notify。

  • “消息”参数表示机器人端希望收到的数据,类型必须为正整数。

程序

MM_RCV_NTFY(MM_NotifyMsg)

参数

参数 描述

输出参数

MM_NotifyMsg

R寄存器号,用于保存通知的消息。

示例

CALL MM_START_VIS(1,20,2)
CALL MM_RCV_NTFY(60)

该示例表示将从 Mech-Vision 工程中获取的通知消息内容保存到寄存器 R[60] 中。

获取 Mech-Vision 自定义数据

该指令用于从 Mech-Vision 中的“输出”步骤接收自定义数据,即除 poses 和 labels 之外其他端口的数据(“输出”步骤参数“端口类型”设置为“自定义”)。

程序

MM_GET_DY_DT(Job,Reg_Pos_Num,Reg_Status)

参数

参数 描述

输入参数

Job

Mech-Vision 工程编号,可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

输出参数

Reg_Pos_Num

R 寄存器号,用于保存返回的视觉点个数,范围为 [1~50]。

Reg_Status

R 寄存器号,用于保存该指令返回的状态码。

示例

CALL MM_GET_DY_DT(1,50,51)

该示例表示接收 Mech-Vision 工程 1 的自定义输出结果,视觉点的数量保存在寄存器 R[50] 中,指令执行的状态码保存在寄存器 R[51] 中。

将获取的 Mech-Vision 自定义输出数据保存至寄存器变量

该指令用于将 Mech-Vision 返回的自定义输出数据结果转存到机器人指定的寄存器变量中,在触发 获取 Mech-Vision 自定义数据 指令之后使用。

程序

MM_GET_DYPOS(Serial,Pr_Num,Reg_Label,Reg_UserData)

参数

参数 描述

输入参数

Serial

指定获取第几个视觉点中的自定义数据。

输出参数

Pr_Num

PR 寄存器号,用于保存指定视觉点的位姿数据。

Reg_Label

R 寄存器号,用于保存指定视觉点的标签数据。

Reg_UserData

R 寄存器号,用于保存指定视觉点的用户自定义数据,此为起始寄存器编号,根据自定义数据数量依次向后进行存储。

示例

CALL MM_GET_DYPOS(1,60,61,62)

该示例表示将接收到的第一个视觉点的位姿数据保存到位置寄存器 PR[60] 中,将相应标签数据保存到寄存器 R[61] 中,将相应的自定义输出数据从寄存器 R[62] 开始依次进行保存。

获取视觉移动规划数据或自定义数据

该指令用于获取Mech-Vision工程的视觉移动规划数据,或者获取Mech-Viz工程的视觉移动规划数据或自定义数据。MM_GET_PLJOP可将获取的数据分配至各变量中。

程序

MM_GET_PLNDT(Resource,Jps_Pos,Reg_Pos_Num,Reg_VPos_Num,Reg_Status)

参数

参数 描述

输入参数

Resource

该参数指定视觉移动规划数据的来源。

  • 0:从Mech-Viz获取视觉移动规划数据。

  • 正整数:从Mech-Vision获取视觉移动规划数据。此处设置的正整数就是Mech-Vision工程编号。

Jps_Pos

预期的返回数据格式,取值范围为 1~4,详情参见下表。

输出参数

Reg_Pos_Num

R 寄存器号,用于保存接收到的路径点个数,范围为 [1~50]。

Reg_VPos_Num

R 寄存器号,用于保存第一个视觉移动在规划路径中的位置编号。

Reg_Status

R 寄存器号,用于保存该指令返回的状态码。

  • 当Resource为0时,Jps_Pos 参数取值范围为 1~4,具体说明如下。

    Jps_Pos 参数值 预期的返回数据 说明(每个字段的具体解释参见下文)

    1

    位姿(JPs 形式), 移动类型, 末端工具编号, 速度, 自定义数据项 1, …, 自定义数据项 N

    2

    位姿(TCP 形式), 移动类型, 末端工具编号, 速度, 自定义数据项 1, …, 自定义数据项 N

    3

    位姿(JPs 形式), 移动类型, 末端工具编号, 速度, Mech-Viz视觉移动规划数据, 自定义数据项 1, …, 自定义数据项 N

    4

    位姿(TCP 形式), 移动类型, 末端工具编号, 速度, Mech-Viz视觉移动规划数据, 自定义数据项 1, …, 自定义数据项 N

  • 当Resource为正整数时,Jps_Pos 参数取值范围为 1~2,具体说明如下。

    Jps_Pos 参数值 预期的返回数据 说明(每个字段的具体解释参见下文)

    1

    位姿(JPs 形式), 移动类型, 末端工具编号, 速度, Mech-Vision视觉移动规划数据

    2

    位姿(TCP 形式), 移动类型, 末端工具编号, 速度, Mech-Vision视觉移动规划数据

位姿

路径点的位姿可以是机器人关节角(JPs,单位为度)或工具位姿(TCP,其中三维坐标单位为毫米,欧拉角单位为度),其形式取决于发送的指令参数。

移动类型

  • 1:关节移动。

  • 2:直线移动。

末端工具编号

路径点的末端工具编号。若值为-1,表示不使用末端工具。

速度

路径点的速度值。

视觉移动规划数据

Mech-Vision或Mech-Viz中“视觉移动”步骤规划的数据,包括被抓取工件的标签、已抓取的工件总数、本次抓取的工件数量、吸盘边角号、TCP偏移量、工件组朝向、单个工件朝向、工件组尺寸。

自定义数据项

当 Mech-Vision 工程中“输出”步骤的端口类型为“自定义”时,除 poses 和 labels 等之外其他自定义端口的数据。 各自定义数据按照端口名称的字母顺序(A—Z)排列。

示例

CALL MM_GET_PLNDT(0,3,50,51,52)

该示例表示接收 Mech-Viz 返回的路径规划,预期的返回数据格式参数为 3,路径点个数保存在寄存器 R[50] 中,视觉移动路径点在路径中的位置编号保存在寄存器 R[51] 中,该指令执行的状态码保存在寄存器 R[52] 中。

将从MM_GET_PLNDT获取的数据保存至各变量

该指令用在获取视觉移动规划数据或自定义数据指令后,用于将获取的数据存放到不同变量中。

程序

MM_GET_PLJOP(Serial,Jps_Pos,Pr_Num,Reg_MoveType,Reg_ToolNum,Reg_Speed,Reg_UserData,Reg_PlanRes)

参数

参数 描述

输入参数

Serial

指定要转存第几个路径点。

Jps_Pos

获取视觉移动规划数据或自定义数据 指令中的 Jps_Pos 所选值一致。

输出参数

Pr_Num

PR 寄存器号,用于保存指定路径点对应的位姿数据。

Reg_MoveType

R 寄存器号,用于保存指定路径点对应的移动类型。1表示关节移动,2表示直线移动。

Reg_ToolNum

R 寄存器号,用于保存指定路径点对应的末端工具编号。若值为-1,表示不使用末端工具。

Reg_Speed

R 寄存器号,用于保存指定路径点对应的移动速度。

Reg_UserData

R 寄存器号,用于保存指定路径点对应的自定义输出数据。此为起始寄存器编号,根据自定义数据数量依次向后进行存储,目前数量最大值为 50。

Reg_PlanRes

R 寄存器号,用于保存指定路径点对应的视觉移动规划数据。此为起始寄存器编号,根据视觉移动规划数据数量依次向后进行存储,目前数量为 21。

视觉移动规划数据的具体内容如下表所示。

数据 说明 对应R寄存器号

被抓取工件的标签

由10个整数组成,默认为10个0

Reg_PlanRes~Reg_PlanRes+9

已抓取的工件总数

累计已抓取的工件数量

Reg_PlanRes+10

本次抓取的工件数量

本次抓取的工件数量

Reg_PlanRes+11

吸盘边角号

本次吸盘所使用的边角号

Reg_PlanRes+12

TCP偏移量

工件组中心相对于末端工具中心的XYZ偏移量

Reg_PlanRes+13~Reg_PlanRes+15

工件组朝向

工件组与吸盘长边的朝向关系,0表示平行,1表示垂直

Reg_PlanRes+16

单个工件朝向

单个工件长边与吸盘长边的朝向关系,0表示平行,1表示垂直

Reg_PlanRes+17

工件组尺寸

本次抓取的工件组的长宽高

Reg_PlanRes+18~Reg_PlanRes+20

示例

CALL MM_GET_PLJOP(1,3,60,61,62,63,81,131)

该示例表示将收到的第一个路径点的位姿数据保存到位置寄存器 PR[60] 中,将移动类型保存到寄存器 R[61] 中,将末端工具编号保存到寄存器 R[62] 中,将移动速度保存到寄存器 R[63] 中,将自定义输出数据从寄存器 R[81] 开始依次进行保存,将视觉移动规划数据从寄存器 R[131] 开始依次进行保存。

获取 Mech-Vision “路径规划”步骤的结果

在启动 Mech-Vision 工程后,该指令用于获取 Mech-Vision 中“路径规划”步骤输出的免碰撞抓取路径。

在使用该指令时,Mech-Vision “输出”步骤的 端口类型 参数需要设置为“预定义(机器人路径)”。

程序

MM_GET_VISP(Job,Jps_Pos,Reg_Pos_Num,Reg_VPos_Num,Reg_Status)

参数

参数 描述

输入参数

Job

Mech-Vision 工程编号,可在 Mech-Vision 工程列表窗口中查看,工程名称前的数字表示工程编号。

Jps_Pos

指定“路径规划”步骤返回的路径点的位姿类型。
1:路径点的位姿将以机器人关节角(JPs)的形式返回。
2:路径点的位姿将以机器人工具位姿(TCP)的形式返回。

输出参数

Reg_Pos_Num

R 寄存器号,用于保存该指令返回的路径点个数,范围为 [1~20]。

Reg_VPos_Num

R 寄存器号,用于保存路径规划工具中设置的“视觉移动”路径点在整个路径中的位置。
例如,如果规划路径由以下组成:“定点移动_1”,“定点移动_2”,“视觉移动”,“定点移动_3”,则“视觉移动”位置为 3。 如果路径中无“视觉移动”,则该参数值为 0。

Reg_Status

R 寄存器号,用于保存该指令返回的状态码。

示例

CALL MM_GET_VISP(1,1,51,52,53)

该示例表示接收 Mech-Vision 工程 1 的路径规划步骤输出结果,路径点的位姿类型为关节角,路径点个数保存在寄存器 R[51] 中,视觉移动路径点在路径中的位置编号保存在寄存器 R[52] 中,指令执行的状态码保存在寄存器 R[53] 中。

读取Mech-Viz步骤参数值

该指令用于读取Mech-Viz工程中指定的步骤参数值。

程序

MM_GET_PROP(Read_id,Reg_Status,Reg_Viz_Prop)

参数

参数 描述

输入参数

Read_id

该参数为property_config文件中指定的 配置编号 字段。

输出参数

Reg_Status

R 寄存器号,用于保存指令状态码,具体可参考《标准接口状态码及错误排查》。

Reg_Viz_Prop

R 寄存器号,用于保存返回的指定步骤的参数值,目前只支持返回INT整型值。

在Mech-Vision工具栏的 机器人通信配置  下一步  高级设置 下,单击 属性配置,即可打开property_config文件。

get property config

在使用该指令前,用户需提前在property_config文件中指定步骤编号和参数名称对应的key名称,具体格式如下所示。

read, 配置编号, 步骤编号, key名称

read

指定该行用于读取步骤参数值。

配置编号

指定一个唯一的编号,为正整数。一个配置编号只能用于读取一个步骤参数值。如果读取多个步骤参数值,请使用不同的配置编号。

步骤编号

指定将要读取的参数所属步骤的编号。

key名称

指定将要读取的参数名称对应的key名称。

  • key名称 可通过 Keys查询工具 获取。单击Mech-Viz菜单栏的 工具  Keys查询工具,即可打开该工具。单击具体步骤图标,中间区域就是选中步骤的所有参数名称对应的key名称。设置的key名称必须是下图区域中出现的名称。

    parameter key name
  • property_config文件中以“#”为开头的内容为注释行,指令在执行代码时会忽略注释,不做任何处理。

  • 对property_config文件编辑完后,注意保存文件,并重启Mech-Vision工具栏中的接口服务。

property_config文件中可以设置多条read指令,但每条read指令的配置编号必须唯一。

示例

例如,在property_config文件中添加如下内容,5表示配置编号,3表示步骤编号,xCount表示key名称。

read, 5, 3, xCount

机器人发送如下指令后,将会获取到xCount对应的参数值。

CALL MM_GET_PROP(5,10,11)

该示例表示将Mech-Viz工程中步骤编号3的xCount对应参数值保存到R[11]寄存器,并将返回的状态码保存在R[10]寄存器中。

设置Mech-Viz步骤参数值

该指令用于设置Mech-Viz工程中指定的步骤参数值。

程序

MM_SET_PROP(Write_id,Reg_Status)

参数

参数 描述

输入参数

Write_id

该参数为property_config文件中指定的 配置编号 字段。

输出参数

Reg_Status

R 寄存器号,用于保存指令状态码,具体可参考《标准接口状态码及错误排查》。

在Mech-Vision工具栏的 机器人通信配置  下一步  高级设置 下,单击 属性配置,即可打开property_config文件。

get property config

在使用该指令前,用户需提前在property_config文件中指定步骤编号、参数名称对应的key名称和参数值,具体格式如下所示。

write, 配置编号, 步骤编号, key名称, 参数值

write

指定该行用于设置步骤参数值。

配置编号

指定一个编号(非唯一),为正整数。

步骤编号

指定将要设置的参数所属步骤的编号。

key名称

指定将要设置的参数名称对应的key名称。

参数值

指定将要设置的参数值。

  • property_config文件中可以设置多条write指令,且配置编号允许重复,即使用一个配置编号设置多个参数值。

  • key名称 可通过 Keys查询工具 获取。单击Mech-Viz菜单栏的 工具  Keys查询工具,即可打开该工具。单击具体步骤图标,中间区域就是选中步骤的所有参数名称对应的key名称。设置的key名称必须是下图区域中出现的名称。

    parameter key name
  • property_config文件中以“#”为开头的内容为注释行,指令在执行代码时会忽略注释,不做任何处理。

  • 对property_config文件编辑完后,注意保存文件,并重启Mech-Vision工具栏中的接口服务。

示例

例如,property_config文件内容如下,1表示配置编号,3表示步骤编号,xOffset、yOffset和zOffset表示key名称,10表示xOffset对应的参数值,20表示yOffset对应的参数值,30表示zOffset对应的参数值。

write, 1, 3, xOffset, 10
write, 1, 3, yOffset, 20
write, 1, 3, zOffset, 30

机器人发送如下指令后,Mech-Viz会将xOffset、yOffset和zOffset对应的参数值分别设置为10、20和30。

MM_SET_PROP(1,10)

该示例表示将xOffset、yOffset和zOffset对应的参数值分别设置为10、20和30,并将返回的状态码保存在R[10]寄存器中。

获取通知的消息

在触发Mech-Vision或Mech-Viz工程运行后,该指令用于获取“通知”步骤中预先设置的消息。

程序

MM_GET_NTFY(MM_NotifyMsg)

参数

参数 描述

输出参数

MM_NotifyMsg

R寄存器号,用于保存通知的消息(暂时只支持整数)。

示例

CALL MM_GET_NTFY(60)

该示例表示将从“通知”步骤获取的消息保存至R[60]寄存器中。

停止Mech-Viz工程

该指令用于停止正在运行的Mech-Viz工程。

程序

MM_Stop_Viz

示例

MM_Stop_Viz

该示例表示停止正在运行的Mech-Viz工程。

我们重视您的隐私

我们使用 cookie 为您在我们的网站上提供最佳体验。继续使用该网站即表示您同意使用 cookie。如果您拒绝,将使用一个单独的 cookie 来确保您在访问本网站时不会被跟踪或记住。