Installer GPHOTO2

La bibliothèque GPHOTO2 est utilisée par des applications pour accéder à une grande variété de modèles d’appareils photo numériques, à l’aide des protocoles standards comme l’USB Mass Storage et PTP, ou à l’aide des protocoles propres aux fabricants.

Dans cet article, je présente l’installation de GPHOTO2 sous MaxOS Sierra et sous Raspbian Stretch.

Installation de GPHOTO2 sur macOS Sierra

L’installation de GPHOTO2 sur macOS Sierra se fait avec Homebrew

brew update
brew install gphoto2
# Ou pour mettre à jour
brew upgrade gphoto2
gphoto2 -v

# gphoto2 2.5.14
#
# Copyright (c) 2000-2016 Lutz Mueller and others
#
# gphoto2 comes with NO WARRANTY, to the extent permitted by law. You may
# redistribute copies of gphoto2 under the terms of the GNU General Public
# License. For more information about these matters, see the files named COPYING.
#
# This version of gphoto2 is using the following software versions and options:
# gphoto2         2.5.14         clang, popt(m), no exif, no cdk, no aa, jpeg, readline
# libgphoto2      2.5.14         all camlibs, clang, ltdl, no EXIF
# libgphoto2_port 0.12.0         clang, ltdl, USB, serial without locking

Installation de GPHOTO2 sur Raspbian Stretch

GPHOTO2 n’est disponible qu’à la version 2.5.4 sur Raspbian Jessie avec la commande sudo apt-get install gphoto2. Il est donc préférable d’utiliser Raspbian Stretch. Sur Raspbian Stretch, la version par défaut est la 2.5.11, mais il est possible d’installer manuellement la version 2.5.14.

sudo apt-get --assume-yes install gphoto2
gphoto2 -v

# gphoto2 2.5.11
#
# Copyright (c) 2000-2016 Lutz Mueller and others
#
# gphoto2 comes with NO WARRANTY, to the extent permitted by law. You may
# redistribute copies of gphoto2 under the terms of the GNU General Public
# License. For more information about these matters, see the files named COPYING.
#
# This version of gphoto2 is using the following software versions and options:
# gphoto2         2.5.11         gcc, popt(m), exif, cdk, aa, jpeg, readline
# libgphoto2      2.5.12         all camlibs, gcc, ltdl, EXIF
# libgphoto2_port 0.12.0         gcc, ltdl, USB, serial without locking

GPHOTO2 entre en conflit avec gvfs-gphoto2-volume-monitor et il est donc nécessaire de le désactiver avec les commandes suivantes :

sudo chmod -x /usr/lib/gvfs/gvfs-gphoto2-volume-monitor
sudo reboot
ssh pi@raspberrypi.local

Pour installer la version 2.5.14

wget http://archive.raspbian.org/raspbian/pool/main/g/gphoto2/gphoto2_2.5.14-1_armhf.deb
wget http://archive.raspbian.org/raspbian/pool/main/libg/libgphoto2/libgphoto2-6_2.5.14-1_armhf.deb
sudo dpkg -i gphoto2_2.5.14-1_armhf.deb libgphoto2-6_2.5.14-1_armhf.deb
rm gphoto2_2.5.14-1_armhf.deb libgphoto2-6_2.5.14-1_armhf.deb
gphoto2 -v

# gphoto2 2.5.14
#
# Copyright (c) 2000-2016 Lutz Mueller and others
#
# gphoto2 comes with NO WARRANTY, to the extent permitted by law. You may
# redistribute copies of gphoto2 under the terms of the GNU General Public
# License. For more information about these matters, see the files named COPYING.
#
# This version of gphoto2 is using the following software versions and options:
# gphoto2         2.5.14         gcc, popt(m), exif, cdk, aa, jpeg, readline
# libgphoto2      2.5.14         all camlibs, gcc, ltdl, EXIF
# libgphoto2_port 0.12.0         gcc, ltdl, USB, serial without locking

Quelques commandes utiles

# Connecter un appareil de photo sur un port USB du Raspberry.
# J’ai testé avec un Nikon D3200 et ça fonctionne
gphoto2 --auto-detect
gphoto2 --abilities
gphoto2 --summary
gphoto2 --list-ports
mkdir gphoto2
cd gphoto2/
gphoto2 --capture-image-and-download --interval 2 --frames 2 --filename=image_%Y-%m-%d_%H-%M-%S.jpg

Pour visionner les photos

Un moyen simple de visionner les photos est de créer un mini serveur web sur le Raspberry. Pour démarrer ce serveur, il suffit d’utiliser les commandes suivantes, puis de copier-coller l’URL (par exemple http://192.168.1.135:4000) dans un navigateur.

# Ces deux commandes peuvent être copiées-collées directement dans le terminal ou mises dans le fichier ~/.bash_profile.
# Voir https://ouilogique.com/installer-raspberry-pi-os-sur-raspberry-pi-sans-clavier-ni-souris-ni-ecran/#configuration.
IP=$(hostname -I | awk '{print $1}')
alias pyserver='PORT=4000; echo -e "\nhttp://localhost:$PORT"; echo -e "http://$IP:$PORT\n"; python -m SimpleHTTPServer $PORT'
# Démarre le serveur (ctrl-C pour l’arrêter)
pyserver

Comme le serveur bloque la ligne de commande, il est préférable de l’utiliser dans un autre shell avec l’utilitaire gnu screen.

Quelques liens


Préparer un appareil Android

source : https://www.xda-developers.com/install-adb-windows-macos-linux/

  • Activer les options de développement
  • Activer le débogage USB

Préparer un Mac

Installer ADB (Android Debug Bridge)

brew update && brew upgrade
brew install android-platform-tools
adb --help | less
adb devices

* daemon not running; starting now at tcp:5037
* daemon started successfully
List of devices attached
R3CR306GCCY	unauthorized

Autoriser sur l’appareil Android

adb devices

List of devices attached
R3CR306GCCY	device
adb shell # CTRL D pour sortir
adb pull /storage/emulated/0/DCIM/Screenshots
adb pull /storage/emulated/0/DCIM/Camera/20240529_105639.heic
adb pull /sdcard/DCIM/Camera/

Idées en vrac

Faut que je mette de l’ordre dans cette section…

https://github.com/Genymobile/scrcpy

brew install scrcpy

https://www.lesimprimantes3d.fr/forum/topic/47189-tuto-octolapse-pour-des-appareils-android-non-support%C3%A9s-par-gphoto2/

adb shell am start -a android.media.action.IMAGE_CAPTURE
adb shell "am start -a android.media.action.STILL_IMAGE_CAMERA"

adb shell "input keyevent KEYCODE_WAKEUP"  #...................... déverrouillage
adb shell "input keyevent KEYCODE_SLEEP" #........................ verrouillage
adb shell "input keyevent KEYCODE_HOME" #......................... écran d'accueil
adb shell "input keyevent KEYCODE_CAMERA" #....................... prise de la photo
adb shell "input keyevent KEYCODE_FOCUS" #........................ focus manuel avant de prendre une photo
adb shell "am start -a android.media.action.IMAGE_CAPTURE" #...... ouverture de l'application photo par défaut
adb shell "am start -a android.media.action.STILL_IMAGE_CAMERA" #. ouverture de l'application photo par défaut
adb shell "am force-stop com.sec.android.app.camera" #............ fermeture de l'application photo
adb shell ls #.................................................... la fonction "ls" classique avec tous les paramètres possibles
adb pull $FullFileName #.......................................... copier de fichier(s)
adb shell rm $FullFileName #...................................... suppression de fichier(s)