This commit is contained in:
hkslover
2024-05-24 13:00:10 +08:00
parent 811f794a5f
commit 5840e5883f
3 changed files with 41 additions and 8 deletions

View File

@@ -0,0 +1,13 @@
import zmq
context = zmq.Context()
socket = context.socket(zmq.REQ)
socket.connect("tcp://localhost:6666")
if __name__ == '__main__':
print('zmq client start....')
while True:
# str1 = input(":")
socket.send_string('')
message = socket.recv_pyobj()
print(message)

View File

@@ -4,7 +4,7 @@ from loguru import logger
import zmq import zmq
from infer import Lane_model_infer from infer import Lane_model_infer
import numpy as np import numpy as np
import cv2
lock = threading.Lock() lock = threading.Lock()
response = {'code': 0, 'data': 0} response = {'code': 0, 'data': 0}
@@ -31,27 +31,28 @@ if __name__ == "__main__":
# 配置日志输出 # 配置日志输出
logger.add(cfg['debug']['logger_filename'], format=cfg['debug']['logger_format'], retention = 5, level="INFO") logger.add(cfg['debug']['logger_filename'], format=cfg['debug']['logger_format'], retention = 5, level="INFO")
camera_cfg = cfg['camera']
# 连接摄像头server 巡线只需要连接前摄像头 # 连接摄像头server 巡线只需要连接前摄像头
context = zmq.Context() context = zmq.Context()
camera_socket = context.socket(zmq.SUB) camera_socket = context.socket(zmq.SUB)
camera_socket.connect(f"tcp://*:{camera_cfg['front_camera_port']}") camera_socket.connect(f"tcp://localhost:{cfg['camera']['front_camera_port']}")
camera_socket.setsockopt(zmq.SUBSCRIBE, '') camera_socket.setsockopt_string(zmq.SUBSCRIBE, "")
logger.info("connect camera success") logger.info("connect camera success")
# 初始化paddle推理器 # 初始化paddle推理器
predictor = Lane_model_infer() predictor = Lane_model_infer()
logger.info("lane model load success") logger.info("lane model load success")
# 启动lane_infer_server线程 # 启动lane_infer_server线程
mythread = threading.Thread(target=server_resp, mythread = threading.Thread(target=server_resp,
args=(camera_cfg['lane_infer_port'],), args=(cfg['server']['lane_infer_port'],),
daemon=True) daemon=True)
mythread.start() mythread.start()
while True: while True:
image_data_bytes = camera_socket.recv(320*240) message = camera_socket.recv()
image = np.frombuffer(image_data_bytes, dtype=np.uint8).reshape((240, 320, 3)) np_array = np.frombuffer(message, dtype=np.uint8)
result = predictor.infer(image) frame = cv2.imdecode(np_array, cv2.IMREAD_COLOR)
frame = cv2.resize(frame,(320,240))
result = predictor.infer(frame)
with lock: with lock:
response['data'] = result response['data'] = result
mythread.join() mythread.join()

View File

@@ -0,0 +1,19 @@
import zmq
import numpy as np
import cv2
context = zmq.Context()
socket = context.socket(zmq.SUB)
socket.connect("tcp://localhost:5555")
socket.setsockopt_string(zmq.SUBSCRIBE, '')
while True:
message = socket.recv()
np_array = np.frombuffer(message, dtype=np.uint8)
frame = cv2.imdecode(np_array, cv2.IMREAD_COLOR)
cv2.imshow("Received", frame)
if cv2.waitKey(1) == 27:
break
cv2.destroyAllWindows()