python开发工业机器人视觉_python 读取图片轮廓使用工业机器人绘制

1.在visual studio编辑python程序,需要引用当前路径.

python开发工业机器人视觉_python 读取图片轮廓使用工业机器人绘制_第1张图片

#visual studio要增加当前文件夹路径

import cv2

import numpy as np

tubian=open("tubian.txt",'w')#图片轮廓转换成的机器人程序MOVEL

img = cv2.imread('shinubi.jpg') #读取要加载的图片

gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) #转换成灰度图

ret, binary = cv2.threshold(gray,127,255,cv2.THRESH_BINARY)#图像上下限调节,127和255可更改

contours, hierarchy = cv2.findContours(binary,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE) #提取轮廓

for i in range(len(contours)):#遍历轮廓条数

for j in range(len(contours[i])): #遍历单条轮廓点数

pose=contours[i][j][0]#取得NUmpy中的点

print(pose)

pose_str = ','.join(str(k) for k in pose)#转换为字符串

ml_q='MoveL [['#ABB工业机器人指令头部

ml_h=',819.84],[0.0228218,-8.8978E-9,-0.99974,2.03117E-10],[0,0,0,0],[9E+9,9E+9,9E+9,9E+9,9E+9,9E+9]], v1000, z50, tool0;'#ABB工业机器人指令尾部

tubian.write(ml_q+pose_str+ml_h+'\n')#写入文件方便复制

print(i,"hang")#在实际中应该增加抬笔,就是机器人向上偏移10mm指令

tubian.close()#关闭文件

cv2.drawContours(img,contours,2,(0,0,255),3) #绘制第二天边缘

cv2.imshow("img", img) #显示图片

cv2.waitKey(0) #等待键盘

#下面为机器人的下笔的第一个点,主要取其头部和尾部,其他点位更换该点的x,y获得

#一般机器人应该对纸张示教工件坐标系

#如果图片过大,可将pose的中之乘以相应系数

#MoveL [[1306.86,798.10,1664.59],[0.463073,-0.237328,0.843968,0.130218],[0,0,-1,0],[9E+9,9E+9,9E+9,9E+9,9E+9,9E+9]], v1000, z50, tool0;

#MoveL [[438.05,0.00,819.84],[0.0228218,-8.8978E-9,-0.99974,2.03117E-10],[0,0,0,0],[9E+9,9E+9,9E+9,9E+9,9E+9,9E+9]], v1000, z50, tool0;

2.在robostudio中建立一个机器人,调整到合适姿态,从示教器中取得第一笔的姿态(整条指令方便python程序引用.)

大概生成了1400条程序,如果机器人运行报错,如(0,0)点位无法到达,请手动删除.

python开发工业机器人视觉_python 读取图片轮廓使用工业机器人绘制_第2张图片

3.运行完成后,打开TCP跟踪,进行轨迹播放,对比原图,如下:

python开发工业机器人视觉_python 读取图片轮廓使用工业机器人绘制_第3张图片

python开发工业机器人视觉_python 读取图片轮廓使用工业机器人绘制_第4张图片

标签:pose,读取,img,python,9E,机器人,cv2,contours

来源: https://blog.csdn.net/xiaoding_ding/article/details/106623792

你可能感兴趣的:(python开发工业机器人视觉)