Como gravar as chamadas de vídeo do Skype no Linux?

28

Gostaria de realizar entrevistas em vídeo gravadas com o Skype e estou procurando uma ferramenta confiável para conseguir isso.

Existe alguma coisa lá fora que não seja lenta ou com bugs?

Estou correndo (K) Ubuntu.

    
por curiousguy 20.04.2011 / 16:13

5 respostas

11

Existe um software recordMyDesktop link que você pode gravar em qualquer parte de sua tela. Eu uso para gravar minhas sessões de skype.

sudo apt-get install recordmydesktop

para instalá-lo a partir dos canais principais.

    
por 29.04.2011 / 10:13
11

Este comando irá capturar sua área de trabalho completa: Então use este comando, sempre que você quiser gravar uma conversação skype (ou qualquer outra coisa)

ffmpeg -f x11grab -s wxga -r 25 -i :0.0 -sameq /tmp/out.mpg   
    
por 22.04.2011 / 09:38
8

Antecedentes

Gravar áudio e vídeo ao vivo durante uma chamada (ou durante qualquer atividade na área de trabalho do X11) não é muito difícil graças ao ffmpeg e à quantidade de artigos de ajuda disponíveis (incluindo este site). No entanto, se você deseja maior qualidade, você alcançará rapidamente os limites da abordagem simples de mídia simultânea que captura e compacta. Daí a necessidade de uma ferramenta (ou conjunto de ferramentas) que permita:

  1. Grave chamadas sem compactação em um arquivo para processamento posterior, reconhecendo que, ao chamar um telefone, estamos interessados apenas em áudio.
  2. Compacte as chamadas gravadas em alta qualidade mais tarde.

Os scripts Bash a seguir ( myrec , myrec-novideo e myproc ) são minha tentativa nessa tarefa. Tenho certeza de que existem maneiras mais simples de escrever esses scripts, mas eu estava aprendendo scripts Bash em movimento (com uma tremenda satisfação quando consegui que funcionasse, devo acrescentar).

Pré-requisitos

  1. ffmpeg
  2. pulseaudio
  3. skype

Se 1 ou 2 não estiverem presentes em seu sistema, instale-os com seu gerenciador de pacotes preferencial (eu uso synaptic ). Por skype , visite www.skype.com .


Gravar vídeo sem perda e sem perda de áudio - myrec

  1. Crie um arquivo de texto
  2. Salve como myrec (ou qualquer outro nome que funcione para você)
  3. Torne o myrec executável emitindo o comando: chmod +x myrec
  4. Cole o código a seguir e modifique a seção User settings para adequar sua configuração:

#!/bin/bash

echo "Record lossless audio and lossless video for further processing."
echo "Created file name always starts with temp_YYYYMMDD_HHMMSS."
echo "Syntax:"
echo "myrec [optional file description]"
echo "Optional file description is appended to the file name, with spaces replaced by underscores."
echo
echo

### User settings - adjust values to suit your system and needs

# I used to have the name of my webcam mic here, but that stopped working after a system update. "default" was the only fix I found. If you have more than one microphone connected, you may need to tell Pulseaudio which mic you want to be the default, I think pavucontrol is the utility for it.
# If you want to try supplying a name here, run pacmd, then within it the command list-sources will give you a list of possible microphones. Use the name field value without angle brackets.
microphone_audio_device="default"

# Run pacmd, within it the command list-sinks will give you a list of devices to choose from. Use the name field value without angle brackets.
speakers_audio_device="alsa_output.pci-0000_00_1b.0.analog-stereo.monitor"

# Select frame size.
# Some standard frame sizes for reference:
# wvga 852x480
# wxga 1366x768
# wsxga 1600x1024
# wuxga 1920x1200
# woxga 2560x1600
# wqsxga 3200x2048
# wquxga 3840x2400
# whsxga 6400x4096
# whuxga 7680x4800
frame_size="wsxga"

# Framerate in frames per second
framerate="30"

# Indicate which screen the video should be recorded from and an optional offset.
# For example:
# :0.0+10,20
# where 0.0 is display.screen number of your X11 server, same as the DISPLAY environment variable. 10 is the x-offset and 20 the y-offset of the frame, measured from the top left corner of the screen to the top left corner of the frame.
frame_position=":0.0"

# Include the trailing slash after target directory name.
# Expect a very large file!
target_directory="/target/directory/name/"

### End of user settings



record_command="ffmpeg -f pulse -thread_queue_size 512k -i $speakers_audio_device -f pulse -thread_queue_size 512k -i $microphone_audio_device -f x11grab -s $frame_size -r $framerate -thread_queue_size 512k -i $frame_position -map 0 -map 1 -map 2 -codec:a copy -codec:v libx264 -qp 0 -preset ultrafast"
temporary_file_prefix="temp_"

# The IFS (Internal Field Separator) system variable stores the character that separates command line arguments.
# We can use it to replace spaces with underscores.
temp=$IFS
IFS='_'
description="$*"
IFS=$temp

if [ $# -eq 0 ]; then
  $record_command $target_directory$temporary_file_prefix'date +%Y%m%d_%H%M%S'.mkv
else
  $record_command $target_directory$temporary_file_prefix'date +%Y%m%d_%H%M%S'_$description.mkv
fi

A gravação de áudio somente é feita por um script separado na seção a seguir.


Grava apenas áudio sem perdas - myrec-novideo

  1. Crie um arquivo de texto
  2. Salve como myrec-novideo (ou qualquer outro nome que funcione para você)
  3. Torne o myrec-novideo executável emitindo o comando: chmod +x myrec-novideo
  4. Cole o código a seguir e modifique a seção User settings para adequar sua configuração:

#!/bin/bash

echo "Record lossless audio for further processing."
echo "Created file name always starts with temp_YYYYMMDD_HHMMSS."
echo "Syntax:"
echo "myrec-novideo [optional file description]"
echo "Optional file description is appended to the file name, with spaces replaced by underscores."
echo
echo


### User settings - adjust values to suit your system

# I used to have the name of my webcam mic here, but that stopped working after a system update. "default" was the only fix I found. If you have more than one microphone connected, you may need to tell Pulseaudio which mic you want to be the default, I think pavucontrol is the utility for it.
# If you want to try supplying a name here, run pacmd, then within it the command list-sources will give you a list of possible microphones. Use the name field value without angle brackets.
microphone_audio_device="default"

# Run pacmd, within it the command list-sinks will give you a list of devices to choose from. Use the name field value without angle brackets.
speakers_audio_device="alsa_output.pci-0000_00_1b.0.analog-stereo.monitor"

# Include the trailing slash after target directory name.
# Expect a large file!
target_directory="/target/directory/name/"

### End of user settings



record_command="ffmpeg -f pulse -thread_queue_size 512k -i $speakers_audio_device -f pulse -thread_queue_size 512k -i $microphone_audio_device -map 0 -map 1 -codec:a copy -codec:a copy"
temporary_file_prefix="temp_"

# The IFS (Internal Field Separator) system variable stores the character that separates command line arguments.
# We can use it to replace spaces with underscores.
temp=$IFS
IFS='_'
description="$*"
IFS=$temp

if [ $# -eq 0 ]; then
  $record_command $target_directory$temporary_file_prefix'date +%Y%m%d_%H%M%S'.mkv
else
  $record_command $target_directory$temporary_file_prefix'date +%Y%m%d_%H%M%S'_$description.mkv
fi


Processar os arquivos gravados - myproc

  1. Crie um arquivo de texto
  2. Salve como myproc (ou qualquer outro nome que funcione para você)
  3. Torne o myproc executável emitindo o comando: chmod +x myproc
  4. Cole o código a seguir e modifique a seção User settings para adequar sua configuração:


#!/bin/bash

echo "Compress files recorded with myrec or myrec-novideo."
echo "For files to be processed they need to reside in the storage directory and start with temp_"
echo "The two audio tracks (mic and speakers) are mixed together into one new stream, but they are also available as separate tracks in the final file."

# Mixing is because players I know cannot play two audio tracks from the same file simultaneously.
# The mic also captures sounds produced by the speakers. It has two effects:
# 1. You can use this single track to hear both yourself (the mic) and whatever came out of your speakers. Personally I did not like the degraded quality of recorded speaker sounds, hence the direct recording off the sound card and mixing that with the mic track.
# 2. Speaker sounds recorded by the mic are slightly delayed when compared to the direct recording off the sound card. The mixed track is thus hard to listen to.
# I do have echo cancellation module loaded in Pulseaudio, perhaps there is something wrong with my configuration?

### User settings

# Indicate storage directory without the trailing slash
storage_directory="/storage/directory/name"

### End of user settings

# Any temp_ file may contain 3 streams (audio, audio, video) indexed as (0, 1, 2), or just 2 streams (audio, audio) indexed as (0, 1).
# A file temp2_ contains just one stream: both audio streams from temp_ mixed.
# The step with temp2_ is necessary as the mixing option (-filter_complex) is a global option (i.e. not stream-specific). Attempts at doing it all in one go prevent the separate tracks from being copied into the final file.

for f in $storage_directory/temp_*
do
  if [ -e ${f/temp_/} ]
  then
    # Do not overwrite an existing final file. Prevents unnecessary work when the script is run regularly as a cron job.
    echo "$f: A final file (without temp_) already exists. Skipping. If you want to reencode, please delete the final file manually."
  else
    # Variable g will contain the name of the second temporary file with both audio streams mixed into one.
    g=${f/temp_/temp2_}

    # Mixing mic and sound card tracks into one stream
    ffmpeg -i "$f" -map 0:0 -map 0:1 -filter_complex amix=inputs=2:duration=longest:dropout_transition=2 -codec:a libvorbis -n "$g"

    # Create the final file: copy the mixed audio stream from temp2_, add and compress both separate audio streams from temp_, compress at high quality the video stream from temp_.
    # The question mark in -map 0:2? tells ffmpeg to ignore the error if this stream (video) is missing. Allows this same script to be used for audio-only recordings.
    ffmpeg -i "$f" -i "$g" -map 1:0 -map 0:0 -map 0:1 -map 0:2? -codec:a:0 copy -codec:a:1 libvorbis -codec:a:2 libvorbis -codec:v libx264 -qp 18 -preset slow -threads 0 -n "${g/temp2_/}"

    # Delete temp2_
    rm "$g"
  fi
done


Graças à flexibilidade de ffmpeg , myproc pode processar arquivos que podem ou não conter o fluxo de vídeo.


Como usar os scripts

  1. Decida onde a janela da videochamada do Skype será exibida na tela e defina o tamanho da janela como uma dimensão desejada. O Skype se lembrará dessa configuração de janela, então você só precisa fazer isso uma vez. Em todas as chamadas subseqüentes, a janela aparecerá no mesmo lugar no mesmo tamanho. Lembre-se de informar myrec das suas configurações. Em geral, tente fazer com que a janela da videochamada fique perto da sua webcam, para que a pessoa do outro lado tenha a chance de pensar que você está olhando-a nos olhos.
  2. Tem uma janela de terminal aberta. Sempre que você quiser começar a gravar, use o comando:

    • para gravar áudio e vídeo: . myrec some description
    • para gravar somente áudio: . myrec-novideo some description

    some description é opcional em ambos os scripts. Você pode usar a tecla Tab para expandir os nomes dos scripts para economizar alguma digitação. ffmpeg começará a gravar em um arquivo chamado temp_YYYYMMDD_HHMMSS_some_description.mkv , em que YYYYMMDD_HHMMSS é a data e a hora da gravação.

  3. Pressione q na janela do terminal em que ffmpeg está gravando quando você estiver pronto para parar.
  4. Execute . myproc para processar (compactar) os arquivos. Você pode fazer isso manualmente ou configurar um trabalho cron para fazer isso enquanto estiver ausente.
  5. Depois de verificar se a compactação ocorreu conforme o esperado, exclua o arquivo temp_ .


Problemas

  1. Não é possível especificar o microfone pelo nome, só pode usar o valor especial default . Eu costumava ter o nome do microfone lá, mas essa configuração parou de funcionar depois de uma atualização do sistema. Pode ser algo restrito apenas à minha configuração ou a pulseaudio .
  2. O áudio do microfone contém minha voz e o som dos alto-falantes. O som dos alto-falantes está ligeiramente atrás do fluxo de áudio gravado diretamente na placa de som. O módulo de cancelamento de eco de Pulse está carregado, mas acho que é apenas para cancelar meu próprio eco de voz. O problema é que, quando o áudio do microfone é misturado ao áudio da placa de som, o pequeno atraso dificulta a escuta do fluxo resultante. Alguém tem uma ideia de como evitar que o microfone grave os sons dos alto-falantes?


Notas finais

Espero que você ache essas ferramentas úteis. Estou ansioso para ouvir seus pensamentos para melhorias e comentários.

    
por 10.11.2015 / 03:41
3

O software Open Broadcaster Software (OBS) vincula todos esses requisitos a um front-end fácil de usar.

É open source e multiplataforma:

Para o Ubuntu 15.04 e posterior:

sudo add-apt-repository ppa:obsproject/obs-studio
sudo apt-get update && sudo apt-get install obs-studio ffmpeg

Para outras distros / versões anteriores do Ubuntu, confira o wiki

    
por 05.09.2017 / 01:26
0

O xvidcap permite que você selecione uma área da sua área de trabalho e grave-a. Comece com o comando

xvidcap

encontre seu vídeo em ./test-0000.mpeg por padrão.

    
por 19.02.2014 / 04:28