fix: robot emulation centroid visualization

main
Artem-Darius Weber 2 months ago
parent a16c0263f2
commit 8342b4d894

Binary file not shown.

Before

Width:  |  Height:  |  Size: 325 KiB

After

Width:  |  Height:  |  Size: 382 KiB

@ -3,37 +3,33 @@ import numpy as np
from Interfaces.RealSense import RealSenseController
from Server.ServerProvider import RealSenseObjectDetectionServer
def get_shot(controller):
depth_matrix = controller.acquisition.get_depth_image()
color_matrix = controller.acquisition.get_color_image()
print(f"RS Data: {depth_matrix.shape}")
return depth_matrix, color_matrix
def draw_boxes_and_vector(image, detections, follow_vector):
def draw_boxes_on_image(image, detections, target, follow_vector):
for detection in detections:
bbox = detection['bbox']
class_name = detection['class_name']
mean_depth = detection['mean_depth']
x1, y1, x2, y2 = bbox
cv2.rectangle(image, (x1, y1), (x2, y2), (0, 255, 0), 2)
color = (0, 0, 255) if detection == target else (0, 255, 0)
cv2.rectangle(image, (x1, y1), (x2, y2), color, 2)
label = f"{class_name}: {mean_depth:.2f} cm"
cv2.putText(image, label, (x1, y1 - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (255, 0, 0), 2)
cv2.putText(image, label, (x1, y1 - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, color, 2)
img_center = (image.shape[1] // 2, image.shape[0] // 2)
vector_endpoint = (int(img_center[0] + follow_vector[0]), int(img_center[1] + follow_vector[1]))
cv2.arrowedLine(image, img_center, vector_endpoint, (0, 0, 255), 2, tipLength=0.3)
follow_text = f"Follow Vector: {follow_vector}"
cv2.putText(image, follow_text, (10, 30), cv2.FONT_HERSHEY_SIMPLEX, 0.7, (255, 255, 255), 2)
return image
def save_results(image, depth_matrix, filename="output_image.png", depth_filename="depth_matrix.npy"):
cv2.imwrite(filename, image)
print(f"Image saved as {filename}")
np.save(depth_filename, depth_matrix)
print(f"Depth matrix saved as {depth_filename}")
if __name__ == "__main__":
controller = RealSenseController()
interface = RealSenseObjectDetectionServer()
@ -44,6 +40,7 @@ if __name__ == "__main__":
if response:
print("Ответ сервера:", response)
detections_info = response.get("detections_info", [])
follow_vector = response.get("follow_vector", [0, 0, 0])
color_matrix_with_boxes = draw_boxes_and_vector(color_matrix.copy(), detections_info, follow_vector)
target = response.get("target", {})
follow_vector = response.get("follow_vector", [])
color_matrix_with_boxes = draw_boxes_on_image(color_matrix.copy(), detections_info, target, follow_vector)
save_results(color_matrix_with_boxes, depth_matrix)

File diff suppressed because one or more lines are too long
Loading…
Cancel
Save