Quais miniaturizadores adicionais estão disponíveis e como os instalo?

9

Pergunta :

O gerenciador de arquivos do Ubuntu,, Nautilusvem com um amplo suporte para visualizações de arquivos. Essas miniaturas são tratadas por programas auxiliares chamados miniaturas.

O número de miniaturizadores pré-instalados com o Ubuntu é limitado e, portanto, alguns tipos de arquivos mais exóticos não são renderizados por padrão.

Quais miniaturas adicionais posso instalar para ativar as visualizações nesses casos?


Perguntas e Respostas relacionadas :

Como instruir o Nautilus a gerar previamente miniaturas?


Nota :

Sinta-se à vontade para contribuir com esta lista editando a resposta do wiki da comunidade. Se você fizer isso, siga as diretrizes nesta discussão sobre meta e use o padrão preexistente para manter a resposta consistente.

Glutanimado
fonte

Respostas:

11

Instruções gerais de instalação


Miniaturas em repositórios e PPAs

Vários miniaturizadores são pré-empacotados e podem ser facilmente instalados no centro de software ou na linha de comando. Esses miniaturizadores não exigem nenhuma configuração adicional e devem funcionar logo após reiniciar o nautilus. Você pode fazer isso com:

nautilus -q 

Considere ler estas perguntas e respostas antes de instalar qualquer coisa de um PPA:

O que são PPAs e como os uso?

Os PPAs são seguros para adicionar ao meu sistema e quais são algumas das "bandeiras vermelhas" a serem observadas?

Scripts personalizados de miniatura no Ubuntu 11.04 e superior

Miniaturas personalizadas que não estão disponíveis nos repositórios devem ser instaladas manualmente. Estas são as etapas que você precisará executar para instalá-las:

Verifique se o script tem alguma dependência listada. Nesse caso, instale-os primeiro.

Faça o download do script e torne-o executável com chmod a+x filethumbnailerou via Nautilus

Designe uma pasta no seu sistema de arquivos para todos os futuros miniatadores e mova o script para ela, por exemplo

mkdir $HOME/.scripts/thumbnailers && mv filethumbnailer $HOME/.scripts/thumbnailers

Em seguida, você precisará registrar seu script no Nautilus . Para fazer isso, crie uma entrada em miniatura /usr/share/thumbnailers. A entrada deve seguir o esquema de nomeação, foo.thumbnaileronde fooé uma expressão de sua escolha (aqui file):

gksudo gedit /usr/share/thumbnailers/file.thumbnailer

As especificações do miniatura seguem este esquema:

[Thumbnailer Entry]
Exec=$HOME/.scripts/thumbnailers/file.thumbnailer %i %o %s
MimeType=application/file;

A Execentrada aponta para o script de miniatura, enquanto o MimeTypecampo designa os MimeTypes relacionados. As variáveis ​​possíveis são:

%i Input file path
%u Input file URI
%o Output file path
%s Thumbnail size (vertical)

As especificações e variáveis ​​variam com cada script. Simplesmente copie e cole o conteúdo da respectiva caixa de texto no arquivo e salve-o.

Os miniaturas devem estar em funcionamento após reiniciar o nautilus ( nautilus -q).

Scripts personalizados de miniatura no Ubuntu 11.04 e abaixo

As versões anteriores do Ubuntu contam com o GConf para associações de miniaturas. Veja aqui para mais informações.


Fontes :

https://live.gnome.org/ThumbnailerSpec

https://bugzilla.redhat.com/show_bug.cgi?id=636819#c29

https://bugs.launchpad.net/ubuntu/+source/gnome-exe-thumbnailer/+bug/752578

http://ubuntuforums.org/showthread.php?t=1881360



Miniaturas por tipo de arquivo


Arquivos CHM

Visão geral

Descrição : com este script, você obterá miniaturas dos seus arquivos chm no gerenciador de arquivos do nautilus. O script usa a maior imagem da página inicial do arquivo chm para gerar a miniatura, geralmente essa será uma imagem da capa.

Criador : monraaf ( http://ubuntuforums.org/showthread.php?t=1159569 )

Dependências :sudo apt-get install python-beautifulsoup python-chm imagemagick

Entrada de miniaturas

[Thumbnailer Entry]
Exec=$HOME/.scripts/thumbnailers/chmthumbnailer %i %o %s
MimeType=application/vnd.ms-htmlhelp;application/x-chm;

Roteiro

#!/usr/bin/env python

import sys, os
from chm import chm
from BeautifulSoup import BeautifulSoup

class ChmThumbNailer(object):
    def __init__(self):
        self.chm = chm.CHMFile()

    def thumbnail(self, ifile, ofile, sz):

        if self.chm.LoadCHM(ifile) == 0:
            return 1

        bestname    = None
        bestsize    = 0
        base        = self.chm.home.rpartition('/')[0] + '/'
        size, data  = self.getfile(self.chm.home)

        if size > 0:
            if self.chm.home.endswith(('jpg','gif','bmp')):
                self.write(ofile, sz, data)
            else:
                soup = BeautifulSoup(data)
                imgs = soup.findAll('img')
                for img in imgs:
                    name = base + img.get("src","")
                    size, data = self.getfile(name)
                    if size > bestsize:
                        bestsize = size
                        bestname = name
                if bestname != None:
                    size, data = self.getfile(bestname)
                    if size > 0:
                        self.write(ofile, sz, data)
        self.chm.CloseCHM()

    def write(self, ofile, sz, data):
        fd = os.popen('convert - -resize %sx%s "%s"' % (sz, sz, ofile), "w")
        fd.write(data)
        fd.close()

    def getfile(self,name):
        (ret, ui) = self.chm.ResolveObject(name)
        if ret == 1:
            return (0, '')
        return self.chm.RetrieveObject(ui)

if len(sys.argv) > 3:
    chm = ChmThumbNailer()
    chm.thumbnail(sys.argv[1], sys.argv[2], sys.argv[3])

Arquivos EPUB

Visão geral

Descrição : epub-thumbnailer é um script simples que tenta encontrar uma capa em um arquivo epub e cria uma miniatura para ele.

Criador : Mariano Simone ( https://github.com/marianosimone/epub-thumbnailer )

Dependências : nenhuma listada, funcionou bem imediatamente

Entrada de miniaturas

[Thumbnailer Entry]
Exec=$HOME/.scripts/thumbnailers/epubthumbnailer %i %o %s
MimeType=application/epub+zip;

Roteiro

#!/usr/bin/python

#  This program is free software: you can redistribute it and/or modify
#  it under the terms of the GNU General Public License as published by
#  the Free Software Foundation, either version 3 of the License, or
#  (at your option) any later version.
#
#  This program is distributed in the hope that it will be useful,
#  but WITHOUT ANY WARRANTY; without even the implied warranty of
#  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#  GNU General Public License for more details.
#
#  You should have received a copy of the GNU General Public License
#  along with this program.  If not, see <http://www.gnu.org/licenses/>.

# Author: Mariano Simone ([email protected])
# Version: 1.0
# Name: epub-thumbnailer
# Description: An implementation of a cover thumbnailer for epub files
# Installation: see README

import zipfile
import sys
import Image
import os
import re
from xml.dom import minidom
from StringIO import StringIO

def get_cover_from_manifest(epub):
    img_ext_regex = re.compile("^.*\.(jpg|jpeg|png)$")

    # open the main container
    container = epub.open("META-INF/container.xml")
    container_root = minidom.parseString(container.read())

    # locate the rootfile
    elem = container_root.getElementsByTagName("rootfile")[0]
    rootfile_path = elem.getAttribute("full-path")

    # open the rootfile
    rootfile = epub.open(rootfile_path)
    rootfile_root = minidom.parseString(rootfile.read())

    # find the manifest element
    manifest = rootfile_root.getElementsByTagName("manifest")[0]
    for item in manifest.getElementsByTagName("item"):
        item_id = item.getAttribute("id")
        item_href = item.getAttribute("href")
        if "cover" in item_id and img_ext_regex.match(item_href.lower()):
            cover_path = os.path.join(os.path.dirname(rootfile_path), 
                                      item_href)
            return cover_path

    return None

def get_cover_by_filename(epub):
    cover_regex = re.compile(".*cover.*\.(jpg|jpeg|png)")

    for fileinfo in epub.filelist:
        if cover_regex.match(os.path.basename(fileinfo.filename).lower()):
            return fileinfo.filename

    return None

def extract_cover(cover_path):
    if cover_path:
        cover = epub.open(cover_path)
        im = Image.open(StringIO(cover.read()))
        im.thumbnail((size, size), Image.ANTIALIAS)
        im.save(output_file, "PNG")
        return True
    return False

# Which file are we working with?
input_file = sys.argv[1]
# Where do does the file have to be saved?
output_file = sys.argv[2]
# Required size?
size = int(sys.argv[3])

# An epub is just a zip
epub = zipfile.ZipFile(input_file, "r")

extraction_strategies = [get_cover_from_manifest, get_cover_by_filename]

for strategy in extraction_strategies:
    try:
        cover_path = strategy(epub)
        if extract_cover(cover_path):
            exit(0)
    except Exception as ex:
        print "Error getting cover using %s: " % strategy.__name__, ex

exit(1)

Arquivos EXE

Visão geral

Descrição : o gnome-exe-thumbnailer é um thumbnailer para o Gnome que fornecerá aos arquivos .exe do Windows um ícone com base em seu ícone incorporado e um ícone genérico "Programa de vinho". Se o programa tiver permissões de execução normais, o ícone incorporado padrão será mostrado. Este miniaturizador também fornecerá um ícone de miniatura para programas executáveis ​​.jar, .py e similares.

Disponibilidade : repositórios oficiais

Instalação

sudo apt-get install gnome-exe-thumbnailer

Arquivos ODP / ODS / ODT e outros arquivos do LibreOffice e Open Office

Visão geral

Descrição: ooo-thumbnailer é um diminuidor de documentos do LibreOffice, OpenOffice.org e Microsoft Office que pode ser usado pelo Nautilus para criar miniaturas para seus documentos, planilhas, apresentações e desenhos.

Disponibilidade : PPA do desenvolvedor (versão mais recente compatível com LibreOffice no Ubuntu 12.04 ou superior)

Instalação

sudo add-apt-repository ppa:flimm/ooo-thumbnailer && apt-get update && apt-get install ooo-thumbnailer
Glutanimado
fonte
E as .xpmimagens? Eu presumi que eles eram tão "padrão" quanto png, jpge bmp, mas o Nautilus não gera visualizações para eles.
precisa saber é o seguinte
Arquivos de imagem XPM tornar bem para mim no Nautilus 3.4: i.imgur.com/XYUZonV.png
Glutanimate
11
Nevermind, eu descobri que não pode lidar com arquivos com comentários antes do /* XPM */cabeçalho, mesmo que eogos exibe finas
MestreLion
Eu acho que você pode encontrar os mimetype do arquivo usandofile -i FILE
Wilf
1

Arquivos ICNS (ícones do Mac OSX)

Visão geral

O Nautilus não gera miniaturas para ícones do Mac OSX devido a alguns erros , mas o suporte é incorporado GdkPixbuf.

Roteiro

Este é um script básico para gerar miniaturas para .icnsarquivos. Uma versão mais robusta pode ser encontrada em https://github.com/MestreLion/icns-thumbnailer

#!/usr/bin/env python
import sys
from gi.repository import GdkPixbuf
inputname, outputname, size = sys.argv[1:]
pixbuf = GdkPixbuf.Pixbuf.new_from_file(inputname)
scaled = GdkPixbuf.Pixbuf.scale_simple(pixbuf, int(size), int(size),
                                       GdkPixbuf.InterpType.BILINEAR)
scaled.savev(outputname, 'png', [], [])

Instalar

Um script de instalação, junto com o .thumbnailerarquivo do Nautilus, está disponível no repositório do projeto icns-thumbnailer

MestreLion
fonte