Amarok/Manual/Vários/Barra de atmosfera

From KDE Wiki Sandbox
< Amarok‎ | Manual‎ | Various
Revision as of 06:00, 8 August 2018 by FuzzyBot (talk | contribs) (Updating to match new version of source page)
Other languages:

Barra de atmosfera

A Barra de atmosfera mostra-lhe a "atmosfera" de uma faixa, onde você pode usar para descobrir quando algo de interessante ocorrer na música.

Para o Amarok exibir as barras de atmosfera das suas músicas, você precisa do programa Moodbar (consulte abaixo por downloads e pacotes executáveis).

O pacote Moodbar necessita do GStreamer e de vários plugins que dependem dos tipos de arquivos que usar (veja os Tipos de arquivo suportados). Você não precisa do pacote phonon-backend-gstreamer para criar arquivos '.mood'.

Existem duas partes da nova implementação do Moodbar: o pacote Moodbar, que contém um programa que recebe um arquivo de música e gera um arquivo '.mood', e o código de suporte no código-fonte do Amarok, que executa o binário e mostra a barra de atmosfera. O pacote Moodbar depende das bibliotecas do GStreamer. Sem o pacote Moodbar, o Amarok não consegue gerar as barras de atmosfera da sua música.

Como alternativa, existe um novo script que irá criar arquivos moodbar para as faixas existentes em uma lista de músicas do Amarok; esta é uma exceção ao descrito acima. O script não precisa de nada, apenas que o Amarok funcione. No entanto, ele só cria os arquivos '.mood' quando forem reproduzidos na Lista de músicas.

O Moodbar é derivado do trabalho de Gavin Wood e Simon O'Keefe, que escreveram os algoritmos; a sua publicação original está aqui.

Resumo de requisitos

  • The Moodbar binary, in your PATH (it should be listed upon running
    which moodbar
    from a console) — Remember to configure the Moodbar package with proper path, e.g. build and install with commands
    ./autogen.sh --prefix=`pkg-config --variable=prefix gstreamer-1.0` && make && sudo make install
  • The GStreamer 1.0 library and plugins for the formats you want Moodbar to be able to analyse. (An earlier GStreamer 0.10 based version is also still available for some distributions)
  • A biblioteca Fastest Fourier Transform In The West (fftw.org) FFTW na versão 3.0 ou superior (pelo menos a versão de ponto flutuante de precisão simples - libfftw3f) — Se a sua plataforma não tiver este suporte, ou caso precise compilar a sua própria versão, lembre-se de configurar o pacote FFTW com o comando
    ./configure --enable-single
  • Uma versão do Amarok com a opção Usar atmosfera na seção Geral da tela de configuração. Isso corresponde às versões 1.4.4 ou posteriores da série 1.4 ou às versões 2.2.2 ou posteriores da série 2.x.
Information
Systems with package managers should automatically install the GStreamer plugins and FFTW along with the Moodbar package if available; this information is provided mostly for people who want or need to compile from source or manually install packages, or where the distribution specific instructions are outdated and no updated moodbar package is yet available.


Utilização

Atualmente, os arquivos '.mood' devem ser gerados manualmente. O Amarok não pode fazer para você. Para fazer isso na sua coleção inteira, use o Script de geração de arquivos Moodbar, descrito abaixo.

Para ativar a visualização das barras de atmosfera no Amarok, ative-as na configuração: Configurações -> Configurar o Amarok -> Geral -> Mostrar barra de atmosfera na barra de progresso. Estas barras devem agora aparecer nas barras da faixa na janela do reprodutor e na Lista de músicas; existirá também um campo de atmosfera que poderá adicionar aos seus leiautes da lista de músicas.

Instalação

Pacotes do código-fonte
Latest release: moodbar-0.1.4.tar.gz — this is the Moodbar source package, which contains the Moodbar program (which generates .mood files from music files), and a GStreamer plugin that does the work. The Moodbar package needs GStreamer 1.0.* installed, plus the 1.0.* version of various plugins. Be sure to install the Moodbar package into the same prefix as GStreamer — follow the instructions in  the summary of requirements chapter. The 0.1.4 is a a fork of original 0.1.2 sources, updated to use GStreamer 1.0. The old 0.1.2 sources are not reliably available online any more, but packages might be still available for some distributions.

Se encontrar algum erro, por favor, envie um relatório para o bugs.kde.org.

Pacotes do Debian
Note
This section contains old instructions for the GStreamer 0.10 based moodbar version 0.1.2, they might be outdated.

A package for Moodbar is now available in Debian unstable. Simply run

apt-get install moodbar

. You will likely also want to install gstreamer0.10-plugins-ugly, gstreamer0.10-plugins-good, and gstreamer0.10-plugins-bad for format support.

Pacotes do Kubuntu e Ubuntu
Note
This section contains old instructions for the GStreamer 0.10 based moodbar version 0.1.2, they might be outdated.

A package for Moodbar is available in the official package repository; just ensure the universe section is activated (which should be default anyway). Just install the package moodbar with your preferred package manager (Kpackagekit, Aptitude, Adept, Synaptic). You will likely also want to install gstreamer0.10-plugins-ugly, gstreamer0.10-plugins-good, and gstreamer0.10-plugins-bad for format support.

Ou, para o instalar, cole isto no Firefox ou Konqueror e tecle Enter.

apt://moodbar,gstreamer0.10-plugins-ugly,gstreamer0.10-plugins-good,gstreamer0.10-plugins-bad?section=universe?refresh=yep
Pacotes ebuild do Gentoo
Note
This section contains old instructions for the GStreamer 0.10 based moodbar version 0.1.2, they might be outdated.

Moodbar is available in Portage, simply

emerge moodbar

Unofficial ebuilds are no longer required.

Versões em RPM
Note
This section contains old instructions for the GStreamer 0.10 based moodbar version 0.1.2, they might be outdated

If you are a rpm-based distro user, you can build a .rpm using rpmbuild with latest gstreamer-plugins-moodbar.spec. The binary package will be soon available for PLD-linux distro.

Fedora
Note
This section contains old instructions for the GStreamer 0.10 based moodbar version 0.1.2, they might be outdated.

In Fedora 7 and higher (up to 16 as of this writing) Moodbar is available in the default repositories. Simply install it with your PackageKit GUI or with the following yum command:

yum install moodbar
Pacotes do openSUSE

GStreamer 1.0 based version 0.1.4 is available in KDE:Extra repository for openSUSE Leap 42.3 and later. An earlier GStreamer 0.10 based version 0.1.2 is also still available in the main repository for some openSUSE versions.

Para mais detalhes sobre a adição de repositórios, veja a Wiki do openSUSE.


1-Click Install for openSUSE - just choose your version and installation procedure will do the rest:


Pacotes da Mandriva
Note
This section contains old instructions for the GStreamer 0.10 based moodbar version 0.1.2, they might be outdated.

First of all, you need to add PLF repositories, so visit easyurpmi.zarb.org and add them to your repositories list. Then simply install the following packages:

  • gstreamer0.10-moodbar
  • gstreamer0.10-plugins-ugly
  • gstreamer0.10-plugins-good
  • gstreamer0.10-plugins-bad
Arch Linux
Note
This section contains old instructions for the GStreamer 0.10 based moodbar version 0.1.2, they might be outdated.

There is a PKGBUILD for Moodbar in the Arch User Repository (AUR) available here.

Para mais informações sobre o AUR e como lidar com os PKGBUILDs, veja as Recomendações dos usuários do AUR.

FreeBSD
Note
This section contains old instructions for the GStreamer 0.10 based moodbar version 0.1.2, they might be outdated.

There is a port: audio/gstreamer-plugins-moodbar here.

Para instalar essa versão:

cd /usr/ports/audio/gstreamer-plugins-moodbar/ && make install clean

Para adicionar o pacote:

pkg_add -r gstreamer-plugins-moodbar

Script de geração de arquivo Moodbar

Aqui está um script simples em Bash que irá adicionar os arquivos .mood à sua coleção. Ele adiciona arquivos mood para todos os arquivos que corresponderem às extensões na pasta atual e em todas as subpastas e, por isso, será melhor executá-lo a partir da sua pasta de músicas principal.

#!/bin/bash
 DIR=${1:-.}
 LAST=~/.moodbar-lastreadsong
 C_RET=0
 
 control_c()        # run if user hits control-c
 {
   echo "" > "$LAST"
   echo "Exiting..."
   exit
 }
 
 if [ -e "$LAST" ]; then
   read filetodelete < "$LAST"
   rm "$filetodelete" "$LAST"
 fi
 exec 9< <(find "$DIR" -type f -regextype posix-awk -iregex '.*\.(mp3|ogg|flac|wma)') # you may need to add m4a and mp4
 while read i
 do
   TEMP="${i%.*}.mood"
   OUTF=`echo "$TEMP" | sed 's#\(.*\)/\([^,]*\)#\1/.\2#'`
   trap 'control_c "$OUTF"' INT
   if [ ! -e "$OUTF" ] || [ "$i" -nt "$OUTF" ]; then
     moodbar -o "$OUTF" "$i" || { C_RET=1; echo "An error occurred!" >&2; }
   fi
 done <&9
 exec 9<&-
 
 exit $C_RET

Copie e cole o texto acima em um arquivo de texto chamado moodbar.sh na sua pasta de músicas e execute os seguintes comandos:

cd /caminho/das/músicas
 bash moodbar.sh

Alternativamente, se o indicado acima não funcionar, você pode tentar:

chmod +x moodbar.sh
 ./moodbar.sh

Isto pode levar bastante tempo em coleções grandes! Repare que as barras de atmosfera não irão aparecer no Amarok até que ele volte a analisar a coleção. Os arquivos mood gerados serão arquivos com ponto (p.ex., com um ponto final como prefixo) ou arquivos ocultos - tenha isto em mente se você não conseguir encontrá-los.

Baseado no script acima, uma alternativa para CPUs com mais de um núcleo:

#!/bin/bash
 NUMCPU="$(grep ^processor /proc/cpuinfo | wc -l)"
 
 find . -type f -regextype posix-awk -iregex '.*\.(mp3|ogg|flac|wma)' | while read i ; do
 
        while [ `jobs -p | wc -l` -ge $NUMCPU ] ; do
                sleep 0.1
        done
 
        TEMP="${i%.*}.mood"
        OUTF=`echo "$TEMP" | sed 's#\(.*\)/\([^,]*\)#\1/.\2#'`
        if [ ! -e "$OUTF" ] ; then
                moodbar -o "$OUTF" "$i" &
        fi
 done


Solução de problemas

  • If the Moodbar executable gives you a bus error, that almost always means it can't decode (or can't find) your file. Take a look at the supported file types below for ideas on which GStreamer plugins to install. You can also try the command below to test whether GStreamer can decode your file:
    gst-launch-1.0 filesrc location=[file] ! decodebin ! fakesink
  • Se estiver usando o plugin do ffmpeg para decodificar os MP3s, você pode receber informações sobre erros de barramento misteriosos. A solução é parar de usar o plugin do ffmpeg, uma vez que ele é extremamente instável — use o mad como alternativa.
  • Se o executável Moodbar lhe disser que não consegue encontrar um elemento — p. ex., ele apresenta uma mensagem de erro do tipo
    Não foi possível criar um elemento do tipo fftwspectrum, por favor, instale-o.
    — isto normalmente significa que você não possui os plugins necessários instalados (veja a lista de plugins aqui) ou que você não instalou o pacote do Moodbar no mesmo prefixo que o GStreamer. Se os arquivos libmoodbar.so e libgstdecodebin.so não estiverem na mesma pasta, então o Moodbar não está instalado no mesmo prefixo que o GStreamer. Por favor, leia o arquivo INSTALL para mais instruções sobre a correta configuração do pacote moodbar. Alternativamente, se você souber o que está fazendo, pode ser mais simples olhar a variável de ambiente GST_PLUGIN_PATH.
  • If you're wondering why the Moodbar isn't working, either not working at all or not working for a particular file, run the command below, where [file] is a music file:
    moodbar -o test.mood [file]
    To generate a test image preview, one can use the commandː
    gst-launch-1.0 filesrc location=[file] ! decodebin ! audioconvert ! fftwspectrum ! moodbar height=50 max-width=300 ! pngenc ! filesink location=mood.png
  • If you have multiple versions of GStreamer installed, make sure all of the required plugins are installed for version 1.0.* -- different versions cannot use each other's plugins.

Tipos de arquivo suportados

You will need various Gstreamer plugins to enable Moodbar to analyze your files. Here is a list of the plugins you will need; make sure to install the 1.0.* version of each plugin:

Tipo de arquivo Plugin necessário Observação
All gstreamer-1.0.*, gst-plugins-base, gst-plugins-good
mp3 gst-plugins-mad (no gst-plugins-ugly) O plugin do ffmpeg tem problemas; não use para mp3
ogg gst-plugins-vorbis, gst-plugins-ogg
flac gst-plugins-flac
mp4 gst-plugins-faad, gst-plugins-bad
musepack gst-plugins-musepack
wma gst-plugins-ffmpeg

Imagens

Barra de atmosfera na barra de progresso do Amarok 2
Barra de atmosfera na barra de progresso do Amarok 2