test.py 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. import asyncio
  2. import aiohttp
  3. import time
  4. import io
  5. import cv2
  6. from logger import logger
  7. from stream import StreamCapture
  8. from infer import DoorInference
  9. from logger import logger
  10. async def upload_image(session, url, payload, files):
  11. try:
  12. form_data = aiohttp.FormData()
  13. # 添加普通表单数据
  14. for key, value in payload.items():
  15. form_data.add_field(key, value)
  16. # 添加文件数据
  17. for key, (filename, content, content_type) in files:
  18. content_io = io.BytesIO(content)
  19. content_io.seek(0)
  20. form_data.add_field(key, content, filename=filename, content_type=content_type)
  21. # 发起 POST 请求
  22. async with session.post(url, data=form_data) as response:
  23. result = await response.text()
  24. logger.info(result)
  25. except Exception as error:
  26. logger.error(f'Error: {str(error)}')
  27. async def process_stream():
  28. logger.info("====== Start Server =======")
  29. human_model_path = "models/work_clo_person_head_hat.pt"
  30. door_model_path = "models/door_classify.pt"
  31. test_area = [[(222, 59), (432, 3), (528, 96), (318, 198)]]
  32. instance = DoorInference(human_model_path, door_model_path, person_areas=None)
  33. ip = '172.19.152.231'
  34. channel = '45'
  35. stream = StreamCapture(ip, channel)
  36. posttime = time.time() - 30
  37. async with aiohttp.ClientSession() as session:
  38. frame = cv2.imread("inference/test.jpg")
  39. image = frame.copy()
  40. result = instance(image)
  41. if len(result) > 0 and time.time() - posttime > 30:
  42. try:
  43. posttime = time.time()
  44. videoTime = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime())
  45. fileTime = time.strftime('%Y-%m-%d-%H:%M:%S', time.localtime())
  46. filename = fileTime + ".jpg"
  47. filenameori = fileTime + "det.jpg"
  48. logger.info(videoTime)
  49. logger.info(result)
  50. for res in result:
  51. cv2.rectangle(image, tuple(map(int, (res.left, res.top))),
  52. tuple(map(int, (res.right, res.bottom))), (255, 0, 0), 4)
  53. success, encoded_image = cv2.imencode('.jpg', image)
  54. if not success:
  55. logger.error('imencode image error')
  56. content = encoded_image.tobytes()
  57. successori, encoded_imageori = cv2.imencode('.jpg', frame)
  58. if not successori:
  59. logger.error('imencode original image error')
  60. contentori = encoded_imageori.tobytes()
  61. payload = {
  62. 'channel': '45',
  63. 'classIndex': '8',
  64. 'ip': '172.19.152.231',
  65. 'videoTime': videoTime,
  66. 'videoUrl': stream.stream_url
  67. }
  68. files = [
  69. ('file', (filename, content, 'image/jpeg')),
  70. ('oldFile', (filenameori, contentori, 'image/jpeg'))
  71. ]
  72. # 使用协程上传图像
  73. await upload_image(session, 'http://172.19.152.231/open/api/operate/upload', payload, files)
  74. except Exception as error:
  75. logger.error(f'Error: {str(error)}')
  76. logger.info("======= EXIT =======")
  77. if __name__ == "__main__":
  78. asyncio.run(process_stream())