Sommaire |
Nos numériseurs sont de mieux en mieux reconnus par SANE, mais je me suis trouvé un peu perplexe devant mon superbe epson 3490 : Maman ! Et les boutons qu'il y a dessus ?
Un début de solution nous est proposé par le projet scanbuttond actuellement proposé en version 0.2.3
Cependant scanbuttond - qui n'est pas basé sur SANE - ne supporte pas non plus tous les scanneurs, et l'apparition du support des boutons dans SANE est en cours. Par exemple le backend avision propose un support des boutons. Cependant, pour que vous puissiez l'utiliser, il vous faudra l'équivalent de scanbuttond. Le projet se nomme KScannerButtons (voir plus bas).
Cet article est écrit sur la base d'un numériseur Epson Prefection Photo 3490 sur une machine tournant sur Debian Sarge.
C'est en fait un petit démon que vous lancerez quand vous le désirez et qui va régulièrement poller le scanneur afin de voir si un des boutons est pressé, et donc éventuellement relaché. Dans le cas d'une action, il va lancer une numérisation et éventuellement d'autres actions sur la base d'un script que vous allez peaufiner vous-même.
| Rappel : si votre distribution contient un paquetage pour scanbuttond, préférez utiliser ce paquetage plutôt que les sources. Certains puristes prétendrons qu'utiliser les sources c'est l'esprit Linux, mais ce sont surtout des problèmes de dépendances non gérées, des choix par forcément simple à faire sur l'utilisation de telle ou telle fonctionnalité du logiciel que l'on désire compiler.
Pour vérifier que votre distribution contient un paquetage pour scanbuttond, il faut utiliser l'outil de gestion de paquetage de celle-ci. Par exemple :
Votre distribution contient aussi presque surement un outil graphique pour obtenir cette information. Pour plus d'information sur ces questions, consulter cette documentation. |
- récupérez le fichier scanbuttond-0.2.3.tar.gz sur http://sourceforge.net/project/showfiles.php?group_id=121589
Personnellement, je l'ai mis dans /usr/local mais vous faites comme vous voulez.
- Décompressez tout cela :
monsuser@blackix:/usr/local$ gunzip scanbuttond-0.2.3.tar.gz monuser@blackix:/usr/local$ tar xvf scanbuttond-0.2.3.tar monuser@blackix:/usr/local$ cd scanbuttond-0.2.3
Ce n'est que du grand classique en fait ;)
monsuser@blackix:/usr/local/scanbuttond-0.2.3$ ./configure monuser@blackix:/usr/local/scanbuttond-0.2.3$ make
Tout devrait bien se passer étape par étape. Il y a, il est vrai beaucoup de lignes qui défilent, mais du moment que l'on ne finit pas sur une ligne d'erreur, ça roule.
On continue dans le classique :
monuser@blackix:/usr/local/scanbuttond-0.2.3$ sudo make install monuser@blackix:/usr/local/scanbuttond-0.2.3$ sudo ldconfig
Cette dernière ligne est à ne pas oublier, sinon attendez-vous plus tard à un message du genre :
monuser@blackix:/usr/local/scanbuttond-0.2.3$ sudo scanbuttond Unable to load backend library "/usr/local/lib/libscanbtnd-backend_meta.so"!
Premièrement, nous allons vérifier que le démon réagit bien aux évènements :
monuser@blackix:/usr/local/scanbuttond-0.2.3$scanbuttond
Rien ne se passe, c'est bon signe... Si vous avez un message d'erreur, quelque chose s'est mal passé ;(
Appuyons donc sur quelques uns des boutons et recherchons si quelque chose est arrivé :
monuser@blackix:/usr/local/scanbuttond-0.2.3$ sudo grep -R scanbuttond /var/log
et là : normalement le plaisir du style :
/var/log/daemon.log:Mar 24 16:19:32 localhost scanbuttond: scanbuttond started /var/log/daemon.log:Mar 24 16:19:38 localhost scanbuttond: button 4 has been pressed. /var/log/daemon.log:Mar 24 16:19:39 localhost scanbuttond: button 4 has been released. /var/log/daemon.log:Mar 24 16:19:41 localhost scanbuttond: button 3 has been pressed. /var/log/daemon.log:Mar 24 16:19:41 localhost scanbuttond: button 2 has been pressed. /var/log/daemon.log:Mar 24 16:19:42 localhost scanbuttond: button 2 has been released. /var/log/daemon.log:Mar 24 16:19:42 localhost scanbuttond: button 1 has been pressed. /var/log/daemon.log:Mar 24 16:19:43 localhost scanbuttond: button 1 has been released.
Essayez donc de suivre en temps réel les évènements, comme cela se passe dans le fichier /var/log/daemon.log (chez moi, pas très clair dans la documentation en anglais) :
monuser@blackix:/usr/local/scanbuttond-0.2.3$ tail -f /var/log/daemon.log
Et en temps réel les nouvelles pressions effectuées s'affichent ! Chouette ! On arrête bien sûr cela par CTRL+C
Tout se passe dans le fichier buttonpressed.sh Chez moi, je ne l'ai pas bougé et laissé dans /usr/local/etc/scanbuttond On trouve dans la documentation beaucoup de possibilités de gérer le fichier .lock, mais dans mon cas, n'ayant qu'un scanner et le le partageant pas, je ne me suis pas embêté avec. J'ai configuré mon scanner pour que le bouton 1 fasse un scan en couleurs et ouvre Gimp avec, le bouton 2 pour la même chose en noir et blanc, les boutons 3 et 4 pour un simple scan dans un fichier (couleur et noir et blanc), histoire de pouvoir faire des scans multi-pages sans quitter le scanner situé à 2 mètres de la tour :
Donc mon fichier buttonpressed.sh :
#!/bin/sh
# This script is started by scanbuttond whenever a scanner button has been pressed.
# Scanbuttond passes the following parameters to us:
# $1 ... the button number
# $2 ... the scanner's SANE device name, which comes in handy if there are two or
# more scanners. In this case we can pass the device name to SANE programs
# like scanimage.
BUTTON="$1"
DEVICE="$2"
PICDIR="/tmp/"
TMPFILE="/tmp/scan-`date +%Y%m%d%H%M%S`.png"
LOCKFILE="/tmp/${DEVICE}.lock"
case $1 in
1)
scanimage --mode Color >$TMPFILE && \
gimp $TMPFILE &
;;
2)
scanimage --mode Gray >$TMPFILE &&\
gimp $TMPFILE &
;;
3)
/usr/local/bin/scanimage --mode Color >$TMPFILE
;;
4)
/usr/local/bin/scanimage --mode Gray >$TMPFILE
;;
esac
buttonpressed.sh (END)
Et les scans, je les récupère dans le répertoire /tmp avec des noms horodatés commençant par scan. De temps en temps, faire le ménage à la main...
KScannerButtons est composé de deux parties :
C'est un petit démon qui va régulièrement interroger le scanneur afin de voir si un des boutons a été pressé. Dans le cas d'une action, il peut lancer un programme (script shell par exemple) afin d'effectuer les actions que vous aurez paramétrées.
KScannerButtons est basé sur les capacités de surveillance des boutons qu'on commence à trouver dans certains backends (le driver) SANE. Par exemple: avision (testé), fujitsu (non testé).
J'ai développé et testé ce logiciel avec un scanner HP 5300C (avision).
Le logiciel se présente sous la forme d'un tarball (fichier .tar.bz2) contenant à la fois la version compilée et les sources.
L'interface graphique nécessite la présence du logiciel Kommander.
| Rappel : si votre distribution contient un paquetage pour KScannerButtons, préférez utiliser ce paquetage plutôt que les sources. Certains puristes prétendrons qu'utiliser les sources c'est l'esprit Linux, mais ce sont surtout des problèmes de dépendances non gérées, des choix par forcément simple à faire sur l'utilisation de telle ou telle fonctionnalité du logiciel que l'on désire compiler.
Pour vérifier que votre distribution contient un paquetage pour KScannerButtons, il faut utiliser l'outil de gestion de paquetage de celle-ci. Par exemple :
Votre distribution contient aussi presque surement un outil graphique pour obtenir cette information. Pour plus d'information sur ces questions, consulter cette documentation. |
Si toutefois aucun paquetage pour votre distribution n'existe, KScannerButtons s'installe classiquement via les sources.
Nous allons installer le logiciel sous KDE. Pour l'installation en ligne de commande (démon uniquement) reportez vous au site de KScannerButtons.
jice@taz:/usr/localtmp$ tar jxvf kscannerbuttons-0.9.tar.bz2 jice@taz:/usr/localtmp$ cd KScannerButtons
jice@taz:/usr/localtmp$ make kdeinstall
C'est gagné ;-)
Voici une copie de l'écran où vous ferez toutes ces actions :
On vient d'évoquer les actions prédéfinies. Celles-ci sont visibles et modifiables dans l'onglet "Actions".
Vous pouvez également y créer vos propres actions.
Il s'agit de scripts shell. La seule subtilité est de savoir que le nom du périphérique se trouve dans la variable $SANE_DEFAULT_DEVICE, et c'est parti.
Par exemple, le code de "one-touch copy" :
TMPFILE=`mktemp`
scanimage \
--device-name $SANE_DEFAULT_DEVICE \
--format tiff --mode Color \
-l 0 -t 0 -x 210mm -y 297mm \
2>/dev/null > ${TMPFILE}.tiff
tiff2ps -z -w 8.27 -h 11.69 \
${TMPFILE}.tiff | lpr
rm -f ${TMPFILE}.tiffNote: dans la version 0.9, l'action one-touch copy est boguée. Il faut remplacer > ${TMPFILE}.ps par | lpr.
Cela peut être beaucoup plus simple, comme en témoigne le code de "one-touch xsane" :
xsane $SANE_DEFAULT_DEVICE
L'écran de création / mise à jour des actions :
Si vous utilisez l'interface graphique, sautez ce paragraphe.
Ce démon, similaire en but et en action avec scanbuttond est basé sur du code expérimental que j'ai trouvé sur le site de SANE.
Lorsque vous cliquez sur [Enregistrer les paramètres], vous générez en fait un script shell qui va être utilisé par le démon.
Le démon est lancé par la commande suivante :
/usr/local/bin/sanebuttonsd --daemon --quiet --script /home/jice/bin/sanebuttond.sh
À chaque appui de bouton, le démon lance le script avec comme paramètre le numéro de bouton pressé (de la même manière que scanbuttond ; le script est d'ailleurs très similaire, je vous invite à consulter le script sanebuttonsd-test.sh).
Vous pouvez le lancer en mode démo (pour tester les boutons) :
[jice@jice ~]$ sanebuttonsd Scanner button 0 Message 0 Scanner button 1 Message 0 Scanner button 2 Message 0 Scanner button 3 Message 0
Pressez [Ctrl]-[C] pour le stopper.
Note: si vous avez plusieurs scanneurs (ou des périphériques v4l comme une carte télé), vous devez préciser à sanebuttond quel scanneur utiliser, en le lançant comme suit :
[jice@jice ~]$ sanebuttonsd avision:libusb:002:004
ou bien :
[jice@jice ~]$ SANE_DEFAULT_DEVICE=avision:libusb:002:004 sanebuttonsd
où "avision:libusb:002:004" est le périphérique de votre scanneur, donné par scanimage -L ou sane-list-scanners (ce dernier est livré avec KScannerButtons).
© 2006 Glorfindel (Frédéric POUPON) et Lea-linux.org, Jice pour la partie KScannerButtons
| | Ce document est publié sous licence Creative Commons Attribution, Partage à l'identique 2.0 : http://creativecommons.org/licenses/by-sa/2.0/ |