Sha256: 5b06eddaeb55b4bb8e580ffd97c75ac535babd6d4b75aa6a10934dc68971d1f4
Contents?: true
Size: 1.36 KB
Versions: 6
Compression:
Stored size: 1.36 KB
Contents
# frozen_string_literal: true module Lolcommits class CaptureLinux < Capturer MPLAYER_FPS = 25 def capture tmpdir = Dir.mktmpdir # Default delay is 1s delay = capture_delay.zero? ? 1 : capture_delay # There's no way to give a capture delay in mplayer, but a number of frame # mplayer's "delay" is actually a number of frames at 25 fps # multiply the set value (in seconds) by 25 frames = delay.to_i * MPLAYER_FPS debug 'calling out to mplayer to capture image' # mplayer's output is ugly and useless, let's throw it away _stdin, stdout, _stderr = Open3.popen3("mplayer -vo jpeg:outdir=#{tmpdir} #{capture_device_string} -frames #{frames} -fps #{MPLAYER_FPS} tv://") # looks like we still need to read the output for something to happen stdout.read debug 'calling out to mplayer to capture image' # get last frame from tmpdir (regardless of fps) all_frames = Dir.glob("#{tmpdir}/*.jpg").sort_by do |f| File.mtime(f) end if all_frames.empty? debug 'failed to capture any image' else FileUtils.mv(all_frames.last, capture_path) debug 'cleaning up' end FileUtils.rm_rf(tmpdir) end private def capture_device_string "-tv device=\"#{capture_device || Dir.glob('/dev/video*').first}\"" end end end
Version data entries
6 entries across 6 versions & 1 rubygems