Importação automática de imagens V2

Versão em inglês.

=Básico=

scribalbum2.py
Esta é uma nova versão do script de importação de imagens que não usa o TKinter, mas o valueDialog nas entradas.

Nesta nova versão você poderá selecionar entre 4 ou 6 imagens por página, além de poder selecionar o diretório através de uma interface gráfica.

As imagens são carregadas na seqüência Acima > Esquerda > Direita > Abaixo.


 * 1) !/usr/bin/env python


 * 1) File: scribalbum2.py
 * 2) criado originalmente em 2005.02.13 por Gregory Pittman
 * 3) modificado em 2006.06.28
 * 4) Atenção: Esta é a versão Carta (padrão EUA)
 * 5) Coloca 4 a 6 imagens por página
 * 6) Esta versão usa uma diálogo de arquivos e
 * 7) de diretório nas seleções.
 * 8) Filtragem automática de casos com
 * 9) .jpg, .png, .tif, .gif, .pdf, e
 * 10) equivalentes em maiúsculo.
 * 11) Cria um novo documento e não falhará se você já tiver criado um.

import scribus import os

filetype = [] dicttype = {'j':'.jpg','p':'.png','t':'.tif','g':'.gif','P':'.pdf'} Dicttype = {'j':'.JPG','p':'.PNG','t':'.TIF','g':'.GIF','P':'.PDF'} nrimages = scribus.messageBox('Imagens','- Papel Carta EUA-\n Quatro Imagens por Página?\nSim = 4, Não = 6',button1=scribus.BUTTON_YES,button2=scribus.BUTTON_NO) imagedir = scribus.fileDialog('Selecione o diretório de imagens','Diretórios',isdir=True) imagetype = scribus.valueDialog('Tipos de imagens','Entre com o tipo de imagem sendo\n j=jpg,p=png,t=tif,g=gif,P=pdf\n "jptgP" seleciona todos','jptgP') for t in imagetype[0:]: filetype.append(dicttype[t]) filetype.append(Dicttype[t]) d = os.listdir(imagedir) D = [] for file in d:   for format in filetype: if file.endswith(format): D.append(file) D.sort

if nrimages == 3: xpos = [15, 310, 15, 310] ypos = [42, 187, 388, 533] if nrimages == 4: xpos = [15, 310, 15, 310, 15, 310] ypos = [42, 42, 290, 290, 533, 533] pwidth = 288 pheight = 217 imagecount = 0 if len(D) > 0: if scribus.newDoc(scribus.PAPER_LETTER, (10,10,20,20),scribus.PORTRAIT, 1, scribus.UNIT_POINTS, scribus.NOFACINGPAGES, scribus.FIRSTPAGERIGHT): while imagecount < len(D): if imagecount > 0: scribus.newPage(-1) framecount = 0 L = scribus.createText(15, 20, 200, 20) scribus.setText("Dir: " + imagedir, L)           scribus.setTextAlignment(scribus.ALIGN_LEFT, L)            scribus.setFont("Luxi Sans Regular", L)            scribus.setFontSize(10, L)            for x,y in zip(xpos,ypos): if imagecount < len(D): f = scribus.createImage(x, y, pwidth, pheight) scribus.loadImage(imagedir + '/' + D[imagecount], f)                   scribus.setScaleImageToFrame(scaletoframe=1, proportional=1, name=f) lenfilename = len(D[imagecount]) Lpiclen = int(5.3 * lenfilename) Lpic = scribus.createText(x, y + 217, Lpiclen, 15) scribus.setText(D[imagecount], Lpic) scribus.setTextAlignment(scribus.ALIGN_RIGHT, Lpic) scribus.setFont("Luxi Mono Regular", Lpic) scribus.setFontSize(8, Lpic) scribus.setFillColor("White", Lpic) imagecount += 1 scribus.setRedraw(1) scribus.redrawAll
 * 1) When 4 pics per page, coords are: (15, 42),(310, 187), (15, 388), (310, 533)
 * 2) When 6 pics per page: (15, 42),(310, 42), (15, 290), (310, 290),(15,533),(310,533)
 * 1) Esta proporção é a certa para fotografias (pelo menos para a minha Olympus digital)
 * 1) framecount = 0
 * 1) L é o quadro no topo de cada página exibindo o nome do diretório
 * 1) Aqui, as imagens são carregadas na página, quatro por vez, então volta ao início e cria uma página nova
 * 1) Lpic é o rótulo de cada imagem com a posição e o comprimento ajustados de
 * 2) acordo com o tamanho do texto. Caso você altere a fonte ou seu tamanho,
 * 3) será necessário alterar apenas o cálculo aproximado.

else: result = scribus.messageBox ('Não encontrado','Nenhuma imagem encontrada com\n esta seleção',scribus.BUTTON_OK)

scribalbum_a4.py
Esta versão coloca 8 imagens em uma página A4 deixando pouco espaço extra. O uso é igual ao descrito acima. Esta versão será atualizada para ser similar em funcionalidade ao script acima (por isso suas strings não estão traduzidas).
 * 1) !/usr/bin/env python


 * 1) File: scribalbum2.py
 * 2) criado originalmente em 2005.02.13 por Gregory Pittman
 * 3) modificado em 2006.06.28
 * 4) Atenção: Esta é a versão A4 (padrão DIN)
 * 5) # Esta versão usa uma diálogo de arquivos e
 * 6) de diretório nas seleções.
 * 7) Filtragem automática de casos com
 * 8) .jpg, .png, .tif, .gif, .pdf, e
 * 9) equivalentes em maiúsculo.
 * 10) Cria um novo documento

from scribus import * import os

filetype = [] dicttype = {'j':'.jpg','p':'.png','t':'.tif','g':'.gif','P':'.pdf'} Dicttype = {'j':'.JPG','p':'.PNG','t':'.TIF','g':'.GIF','P':'.PDF'}

imagedir = valueDialog('Images','Enter the Image Directory') imagetype = valueDialog('Image Types','Enter the Image Types, where\n j=jpg,p=png,t=tif,g=gif,P=pdf\n "jptgP" selects all','jptgP') for t in imagetype[0:]: filetype.append(dicttype[t]) filetype.append(Dicttype[t])

D=[] d = os.listdir(imagedir) for file in d:   for format in filetype: if file.endswith(format): D.append(file) D.sort xpos = (25, 321) ypos = (42, 236, 430, 624) pwidth = 250 pheight = 187 imagecount = 0 if len(D) > 0: if newDoc(PAPER_A4, (10,10,20,20),PORTRAIT, 1, UNIT_POINTS, NOFACINGPAGES, FIRSTPAGERIGHT): while imagecount < len(D): if imagecount > 0: newPage(-1) L = createText(15, 20, 200, 20) setText("Dir: " + imagedir, L)           setTextAlignment(ALIGN_LEFT, L)            setFont("Luxi Sans Regular", L)            setFontSize(10, L)            for yframe in ypos: for xframe in xpos: if imagecount < len(D): f = createImage(xframe, yframe, pwidth, pheight) loadImage(imagedir + '/' + D[imagecount], f)                       setScaleImageToFrame(scaletoframe=1, proportional=1, name=f) lenfilename = len(D[imagecount]) Lpiclen = int(5.3 * lenfilename) Lpic = createText(xframe + (250 - Lpiclen), yframe + 172, Lpiclen, 15) setText(D[imagecount], Lpic) setTextAlignment(ALIGN_RIGHT, Lpic) setFont("Luxi Mono Regular", Lpic) setFontSize(8, Lpic) setFillColor("White", Lpic) imagecount = imagecount + 1 setRedraw(1) redrawAll
 * 1) There are 8 pictures per page; xpos and ypos are the x,y coord of the upper left corners
 * 1) This proportion is right for photographs (at least for my digital Olympus)
 * 1) L is the frame at the top of each page showing the directory name
 * 1) Here is where we're loading images into the page, eight at a time, then go back up for a newPage
 * 1) Lpic is the label for each picture, with position and length adjusted according to the text length
 * 2) so if you change in font or its size, you may need to adjust this only approximate calculation

else: result = messageBox ('Not Found','No Images found with\n this search selection',BUTTON_OK)