• <bdo id='7KHKF'></bdo><ul id='7KHKF'></ul>
    <tfoot id='7KHKF'></tfoot>

      1. <small id='7KHKF'></small><noframes id='7KHKF'>

        <i id='7KHKF'><tr id='7KHKF'><dt id='7KHKF'><q id='7KHKF'><span id='7KHKF'><b id='7KHKF'><form id='7KHKF'><ins id='7KHKF'></ins><ul id='7KHKF'></ul><sub id='7KHKF'></sub></form><legend id='7KHKF'></legend><bdo id='7KHKF'><pre id='7KHKF'><center id='7KHKF'></center></pre></bdo></b><th id='7KHKF'></th></span></q></dt></tr></i><div id='7KHKF'><tfoot id='7KHKF'></tfoot><dl id='7KHKF'><fieldset id='7KHKF'></fieldset></dl></div>
      2. <legend id='7KHKF'><style id='7KHKF'><dir id='7KHKF'><q id='7KHKF'></q></dir></style></legend>

      3. opencv+mediapipe实现人脸检测及摄像头实时示例

        本文将介绍使用OpenCV和MediaPipe库实现人脸检测的步骤,并提供两个示例:
        <tfoot id='JPxKb'></tfoot>
        <i id='JPxKb'><tr id='JPxKb'><dt id='JPxKb'><q id='JPxKb'><span id='JPxKb'><b id='JPxKb'><form id='JPxKb'><ins id='JPxKb'></ins><ul id='JPxKb'></ul><sub id='JPxKb'></sub></form><legend id='JPxKb'></legend><bdo id='JPxKb'><pre id='JPxKb'><center id='JPxKb'></center></pre></bdo></b><th id='JPxKb'></th></span></q></dt></tr></i><div id='JPxKb'><tfoot id='JPxKb'></tfoot><dl id='JPxKb'><fieldset id='JPxKb'></fieldset></dl></div>

          <bdo id='JPxKb'></bdo><ul id='JPxKb'></ul>
            <tbody id='JPxKb'></tbody>
                <legend id='JPxKb'><style id='JPxKb'><dir id='JPxKb'><q id='JPxKb'></q></dir></style></legend>

                  <small id='JPxKb'></small><noframes id='JPxKb'>

                  OpenCV+MediaPipe实现人脸检测及摄像头实时示例

                  本文将介绍使用OpenCV和MediaPipe库实现人脸检测的步骤,并提供两个示例:

                  1. 人脸检测及关键点标注
                  2. 摄像头实时人脸检测及关键点标注

                  安装所需库

                  首先,需要安装好OpenCV和MediaPipe库。

                  对于Python用户,可以使用pip命令来安装

                  pip install opencv-python
                  pip install mediapipe
                  

                  人脸检测及关键点标注

                  在本示例中,使用的是Mediapipe库中的FaceMesh模块进行人脸检测和关键点标注。

                  import cv2
                  import mediapipe as mp
                  
                  cap = cv2.VideoCapture(0)
                  
                  mp_face_mesh = mp.solutions.face_mesh
                  face_mesh = mp_face_mesh.FaceMesh()
                  
                  while True:
                      ret, frame = cap.read()
                  
                      # 反转图像
                      frame = cv2.flip(frame, 1)
                  
                      # 检测人脸
                      result = face_mesh.process(frame)
                  
                      # 获取关键点坐标
                      if result.multi_face_landmarks:
                          for face_landmarks in result.multi_face_landmarks:
                              for landmark in face_landmarks.landmark:
                                  x = int(landmark.x * frame.shape[1])
                                  y = int(landmark.y * frame.shape[0])
                                  # 在关键点处绘制圆点
                                  cv2.circle(frame, (x, y), 3, (0, 255, 0), -1)
                  
                      cv2.imshow('Face Mesh', frame)
                  
                      if cv2.waitKey(1) & 0xFF == ord('q'):
                          break
                  
                  cap.release()
                  cv2.destroyAllWindows()
                  

                  在这段代码中,我们直接调用了FaceMesh模块,并通过调用其process()方法来实现人脸检测和关键点标注。其中用到了cv2.flip()方法来实现镜像翻转的效果,以提高用户体验。

                  摄像头实时人脸检测及关键点标注

                  在这个示例中,我们将使用OpenCV自带的摄像头,并将检测结果实时显示到窗口中。

                  import cv2
                  import mediapipe as mp
                  
                  mp_face_mesh = mp.solutions.face_mesh
                  face_mesh = mp_face_mesh.FaceMesh()
                  
                  cap = cv2.VideoCapture(0)
                  
                  while True:
                      ret, frame = cap.read()
                  
                      # 反转图像
                      frame = cv2.flip(frame, 1)
                  
                      # 检测人脸
                      result = face_mesh.process(frame)
                  
                      # 获取关键点坐标
                      if result.multi_face_landmarks:
                          for face_landmarks in result.multi_face_landmarks:
                              for landmark in face_landmarks.landmark:
                                  x = int(landmark.x * frame.shape[1])
                                  y = int(landmark.y * frame.shape[0])
                                  # 在关键点处绘制圆点
                                  cv2.circle(frame, (x, y), 3, (0, 255, 0), -1)
                  
                      # 显示结果
                      cv2.imshow('Face Mesh', frame)
                  
                      # 按 'q'键 退出程序
                      if cv2.waitKey(1) & 0xFF == ord('q'):
                          break
                  
                  # 释放摄像头并销毁所有窗口
                  cap.release()
                  cv2.destroyAllWindows()
                  

                  在这个示例中,我们使用了OpenCV自带的VideoCapture()函数获取到了摄像头的输入,并将实时检测的结果实时显示在窗口中。另外,我们也可使用cv2.imwrite()和cv2.VideoWriter()方法将实时输出保存为图片和视频文件。

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  Python中有三个内置函数eval()、exec()和compile()来执行动态代码。这些函数能够从字符串参数中读取Python代码并在运行时执行该代码。但是,使用这些函数时必须小心,因为它们的不当使用可能会导致安全漏洞。
                  在Python中,下载网络文本数据到本地内存是常见的操作之一。本文将介绍四种常见的下载网络文本数据到本地内存的实现方法,并提供示例说明。
                  来给你详细讲解下Python 二进制字节流数据的读取操作(bytes与bitstring)。
                  Python 3.x 是 Python 2.x 的下一个重大版本,其中有一些值得注意的区别。 Python 3.0中包含了许多不兼容的变化,这意味着在迁移到3.0之前,必须进行代码更改和测试。本文将介绍主要的差异,并给出一些实例来说明不同点。
                  要在终端里显示图片,需要使用一些Python库。其中一种流行的库是Pillow,它有一个子库PIL.Image可以加载和处理图像文件。要在终端中显示图像,可以使用如下的步骤:
                  在Python中,我们可以使用Pillow库来进行图像处理。具体实现两幅图像合成一幅图像的方法如下:
                    <tbody id='pBjXt'></tbody>

                  <tfoot id='pBjXt'></tfoot>

                      <legend id='pBjXt'><style id='pBjXt'><dir id='pBjXt'><q id='pBjXt'></q></dir></style></legend>
                      1. <small id='pBjXt'></small><noframes id='pBjXt'>

                        • <i id='pBjXt'><tr id='pBjXt'><dt id='pBjXt'><q id='pBjXt'><span id='pBjXt'><b id='pBjXt'><form id='pBjXt'><ins id='pBjXt'></ins><ul id='pBjXt'></ul><sub id='pBjXt'></sub></form><legend id='pBjXt'></legend><bdo id='pBjXt'><pre id='pBjXt'><center id='pBjXt'></center></pre></bdo></b><th id='pBjXt'></th></span></q></dt></tr></i><div id='pBjXt'><tfoot id='pBjXt'></tfoot><dl id='pBjXt'><fieldset id='pBjXt'></fieldset></dl></div>
                            <bdo id='pBjXt'></bdo><ul id='pBjXt'></ul>