Fork of https://gitlab.com/megapixels-org/Megapixels

Martijn Braam cca7e6a823 Fixed corrupt last frame and metadata 4 lat temu
.builds 737f4fd1c5 Fixed dependencies for alpine CI 4 lat temu
config cca7e6a823 Fixed corrupt last frame and metadata 4 lat temu
.gitignore db131f2cb0 Chosen project name 4 lat temu
CMakeLists.txt db131f2cb0 Chosen project name 4 lat temu
LICENSE db131f2cb0 Chosen project name 4 lat temu
README.md 4fb0a5b133 Change up config lookup and add documentation for it 4 lat temu
camera.css 35770cfa3d Added end-user errors 4 lat temu
camera.glade e713540974 Use symbolic icons 4 lat temu
folder-symbolic.svg e713540974 Use symbolic icons 4 lat temu
ini.c 94d437df30 Added config file parser and meson script 5 lat temu
ini.h 94d437df30 Added config file parser and meson script 5 lat temu
main.c cca7e6a823 Fixed corrupt last frame and metadata 4 lat temu
meson.build e70eebe34b Implement DNG raw burst capture 4 lat temu
org.postmarketos.Megapixels.desktop 4be3e43b3a Added launcher 4 lat temu
org.postmarketos.Megapixels.gresource.xml e713540974 Use symbolic icons 4 lat temu
org.postmarketos.Megapixels.svg 2f3b1afe2d Improved icon 4 lat temu
quickdebayer.c 9871fe602d Improved debayer implementation 4 lat temu
quickdebayer.h 243ef89cb5 Added quick'n'bad debayer implementation for previews 4 lat temu
settings-symbolic.svg e713540974 Use symbolic icons 4 lat temu
shutter-button.svg 83c86ac45d Add button for last image and directory 4 lat temu
switch-camera.svg efb26135bd Use gresources and add new camera icon 4 lat temu

README.md

Megapixels

A GTK3 camera application that knows how to deal with the media request api

Building

$ meson build
$ cd build
$ ninja
$ sudo ninja install

Developing

See the mailing list and issue tracker on https://sr.ht/~martijnbraam/Megapixels/

Config

Megapixels checks multiple locations for it's configuration file and uses the first one it finds. As first step it will get the first compatible name in the device tree, in the case of a PinePhone this might be "pine64,pinephone-1.2". Then that dtname will be used as the filename in the search path in this order:

  • $XDG_CONFIG_DIR/megapixels/config/$dtname.ini
  • ~/.config/megapixels/config/$dtname.ini
  • /etc/megapixels/config/$dtname.ini
  • /usr/share/megapixels/config/$dtname.ini

The files in /usr/share/megapixels should be the config files distributed in this repository. The other locations allow the user or distribution to override config.

Config file format

Configuration files are INI format files.

[device]

This provides global info, currently only the csi key exists, telling megapixels which device in the media-ctl tree is the interface to the kernel. This should provide the /dev/video* node.

[rear] and [front]

These are the sections describing the sensors.

  • driver=ov5640 the name of the media node that provides the sensor and it's /dev/v4l-subdev* node.
  • width=640 and height=480 the resolution to use for the sensor
  • rate=15 the refresh rate in fps to use for the sensor
  • fmt=BGGR8 sets the pixel and bus formats used when capturing from the sensor, only BGGR8 is fully supported
  • rotate=90 the rotation angle to make the sensor match the screen