Kivy 简明教程

Kivy - Camera

借助 Kivy 中的相机小部件,可以显示来自相机设备的视频流。Kivy 可能需要一些时间来初始化相机设备,然后更新小部件纹理。

Camera 类在 "kivy.uix.camera: 模块中定义。

from kivy.uix.camera import Camera
cam = Camera(**kwargs)

如果系统找到多个相机设备,你需要根据其索引指定要使用的相机。

cam = Camera(index=1)

你还可以通过 resolution 参数指定相机分辨率:

cam = Camera(index=1, resolution=(640, 480))

kivy.uix.camera.Camera 类是 "kivy.core.camera" 模块中核心 Camera 类的具体实现,并执行初始化和帧捕获函数。

Kivy 需要找到合适的摄像头提供器,以便检测硬件。为此,安装最新版本的 opencv-python 包,该包还安装其依赖项包,包括 NumPy。

pip install opencv-python

若要从摄像头上向应用窗口传输视频流,请将 Camera 对象的播放属性设置为 True,将其设置为 False 则停止视频传输。

cam.play = True

若要将摄像头视频流的快照保存到图片中,请使用 export_to_png() 方法。指定要保存的文件名。

Camera 类定义了以下属性 −

  1. index − 使用的摄像头的索引,从 0 开始。将其设置为 -1 以允许自动选择。

  2. play − 用于指示摄像头是否正在播放的布尔值。你可以通过设置此属性来启动/停止摄像头 −

# create the camera, and start later (default)
cam = Camera()

# and later
cam.play = True

# to sop
cam.play = False
  1. resolution − 调用摄像头时使用的首选分辨率。如果你使用的是 [-1, -1],那么分辨率将为默认分辨率。要设置所需分辨率(前提是该设备支持该分辨率)−

cam = Camera(resolution=(640, 480))

Example

以下示例代码在垂直 BoxLayout 内添加了一个 Camera 控件和一个 ToggleButton。与切换按钮绑定的回调在按钮按下时将摄像头对象的播放属性设置为 True,否则停止视频。

from kivy.app import App
from kivy.uix.boxlayout import BoxLayout
from kivy.uix.togglebutton import ToggleButton
from kivy.uix.camera import Camera
from kivy.core.window import Window

Window.size = (720,350)

class TestCameraApp(App):
   def build(self):
      box=BoxLayout(orientation='vertical')
      self.mycam=Camera(play=False, resolution= (640, 480))
      box.add_widget(self.mycam)
      tb=ToggleButton(text='Play', size_hint_y= None, height= '48dp')
      tb.bind(on_press=self.play)
      box.add_widget(tb)
      return box

   def play(self, instance):
      if instance.state=='down':
         self.mycam.play=True
         instance.text='Stop'
      else:
         self.mycam.play=False
         instance.text='Play'

TestCameraApp().run()

Output

运行代码并检查输出 −

kivy camera

你还可以使用 “kv” 语言脚本设计应用程序窗口布局。将以下脚本另存为 “TestCamera.kv”,将 build() 方法中的代码注释掉,并只在其中放置一条 “pass” 语句。

BoxLayout:
   orientation: 'vertical'
   Camera:
      id: camera
      resolution: (640, 480)
      play: False
   ToggleButton:
      text: 'Play'
      on_press: camera.play = not camera.play
      size_hint_y: None
      height: '48dp'