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

Version Path
lolcommits-0.17.2 lib/lolcommits/capturer/capture_linux.rb
lolcommits-0.17.1 lib/lolcommits/capturer/capture_linux.rb
lolcommits-0.17.0 lib/lolcommits/capturer/capture_linux.rb
lolcommits-0.16.5 lib/lolcommits/capturer/capture_linux.rb
lolcommits-0.16.4 lib/lolcommits/capturer/capture_linux.rb
lolcommits-0.16.3 lib/lolcommits/capturer/capture_linux.rb