2025-05-29 11:46:58 +08:00

69 lines
2.0 KiB
Python

import os
import sys
current_file_path = os.path.abspath(__file__)
dobot_nova5_path = os.path.dirname(os.path.dirname(current_file_path))
print(dobot_nova5_path)
sys.path.append(dobot_nova5_path)
from hardware.dobot_nova5 import dobot_nova5
import cv2
from hardware.remote_cam import ToolCamera
import threading
import numpy as np
import time
class Getpose:
def __init__(self):
self.arm = dobot_nova5()
self.arm.start()
self.arm.init()
self.cam = ToolCamera(host='127.0.0.1')
self.cam.start()
time.sleep(2)
self.thread1=threading.Thread(target=self.show)
self.thread1.start()
self.pose_data=[]
self.image_data=[]
self.arm.start_drag()
def show(self):
while True:
self.rgb, self.depth, intrinsics = self.cam.get_latest_frame()
# print("cv:",self.rgb)
cv2.imshow("1111",self.rgb)
cv2.waitKey(1)
time.sleep(0.2)
def add_data(self):
angle=self.arm.getAngel()
self.pose_data=self.pose_data.append(angle)
print(angle)
def save_data(self):
data=np.array(self.pose_data)
np.savetxt('pose.txt', data ,fmt='%.5f')
if __name__ == "__main__":
save_directory = '/home/jsfb/jsfb_ws/global_config/captured_images'
if not os.path.exists(save_directory):
os.makedirs(save_directory)
sele=Getpose()
key = cv2.waitKey(1) & 0xFF
while True:
i=1
if key == ord('s'):
img_path = f'photo{i}.png'
filename = os.path.join(save_directory, img_path)
cv2.imwrite(filename, sele.rgb) # 保存照片
sele.add_data()
filename2 = os.path.join(save_directory, f'pose.txt')
np.savetxt(filename2, sele.pose_data)
# pose = increase_dof(poselist[index])
i += 1
# 按下'q'键退出循环
elif key == ord('q'):
sele.arm.disableRobot()
break