Awesome
Damselfly - A Photo Management System
Damselfly is a server-based Digital Photograph Management system. Damselfly is designed to manage a large, folder-based collection of photographs, with a particular focus on fast search and keyword-tagging workflow.
Damselfly includes powerful Machine Learning functions which can help you identify photographs and their subjects, including face detection, face recognition and object detection - allowing you to tag people once, and have Damselfly identify other photos in which they appear.
The user-interface and workflow is loosely based on the much-loved Google Picasa app, with a basket to select images for export and other types of processing. Damselfly also provides a desktop/client app which gives closer integraton with your laptop or PC, allowing you to quickly sync a selection of images from the Damselfly basket to a local folder, for editing etc.
Features
- Support for most image formats including JPG, PNG, HEIC, TIFF, Webp, BMP and DNG/CR2/ORF/NEF (RAW) files.
- AI / Computer vision image recognition:
- Facial detection
- Facial Recognition
- Object detection and recognition
- Image Colour Classification
- Full-text search with multi-phrase partial-word searches
- Image re-organisation - move/copy images between folders, and delete images (via a trashcan folder)
- Advanced search - filter by:
- Find visually similar images
- Date ranges
- Objects/Faces/Identified faces
- Camera/Lens Make/Model
- File Size
- Orientation
- Images with no keyword tags
- Focus on extremely fast performance - searching a 500,000-image catalogue returns results in less than a second.
- Fast keyword tagging workflow with non-destructive EXIF data updates (using ExifTool) - so JPEGs are not re-encoded when keyword-tagged
- Face detection and recognition, and object recognition in images
- Multi-user support with user accounts, and role-based entitlements (e.g., users with ReadOnly role are prevented from keyword-tagging images)
- Download/export processing to watermark images ready for social media, or sending via Email etc.
- GeoLocation with map display of photo locations where metadata exists
- Selection basket for saving images from search results:
- Images within the basket can be downloaded, exported for use within Digikam/PhotoShop/etc., or uploaded to Wordpress
- Baskets can be user-specific, or shared with other users
- Server-based deployment, with a web-based front-end UI, so the image library can be accessed via multiple devices without having to copy catalogues or other DBs to local device storage.
- Exclude images from Damselfly scanning by adding a
.nomedia
file in any folder. - Themes
- Completely automated background indexing of images, so that the collection is automatically and quickly updated when new images are added or updated
- Background thumbnail generation
- Electron.Net Desktop Client for hosted site to allow closer native integration with client OS
- Desktop Client versions for MacOS (universal), Windows and Linux
- Synchronise images from server basket select to local filesystem for editing
- Other integrations coming in future
- Runs on Windows, Linux and OSX, and in Docker.
- Built with Microsoft .Net 7, hosted Blazor WebAssembly and EFCore 7.
Update on Damselfly Face Recognition Support
Damselfly used to provide face-recognition via the Microsoft Azure Face API. However, Microsoft have recently locked down the use of this API.
The latest version of Damselfly now supports full face detection and recognition locally and offline.
Want to Support Damselfly?
Damselfly is free, open-source software. But if you find it useful, and fancy buying me a coffee or a slice of pizza, that would be appreciated!
<a href="https://www.buymeacoffee.com/damselfly" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/arial-green.png" alt="Buy Me A Coffee" height="41" width="174"></a>
Getting in Touch
You can follow Damselfly on Twitter or ask questions/get support on Reddit (r/DamselflyPhotos). If you have problems, feature requests or have found a bug, you can raise an issue. Or if you want to say hello, email me.
Screenshots
<div> <img style="margin: 5px;" src="docs/Damselfly-browsing.jpg" alt="Browsing in Damselfly" width="600"/> <img style="margin: 5px;" src="docs/Damselfly-theme.jpg" alt="Themes in Damselfly" width="600"/> <br/> <br/> <img style="margin: 5px;" src="docs/Damselfly-imageview.jpg" alt="Viewing images in Damselfly" width="600"/> <img style="margin: 5px;" src="docs/Damselfly-AI.jpg" alt="Face and Object Detection in Damselfly" width="600"/> <br/> <img style="margin: 5px;" src="docs/Damselfly-grouping.jpg" alt="Browsing images grouped by date Damselfly" width="600"/> <div>Planned Features/Enhancements
- Simple non-destructive editing/manipulation - cropping, colour adjustment etc (in progress)
- Image de-duplication (in progress)
- Support for more image formats, and possibly video
- Support for selection and upload to Alamy Stock Image photo service
- Synchronisation of local images back to the server
- If you have ideas for other features - let me know by raising an issue!
How should I use Damselfly? What's the workflow?
The photos live in the library on the server, but whenever you want to work on a picture (e.g., in Photoshop, Digikam or your editing tool of choice) you use the Damselfly Deskop app to add the images to the basket, and choose Download => Save Locally, to sync the pictures across the network to your local folder. Once you've finished editing, copy them back to the server (a future feature enhancement will let Damselfly do this for you) where the server will re-index them to pick up your changes.
Suggested workflow.
- Images are copied onto a laptop for initial sorting, quality checks, and IPTC tagging using Picasa or Digikam
- Rclone script syncs the new images across the LAN to the network share
- Damselfly automatically picks up the new images and indexes them (and generates thumbnails) within 30 minutes
- Images are now searchable in Damselfly and can be added to the Damselfly 'basket' with a single click
- Images in the basket can be copied back to the desktop/laptop for local editing in Lightroom/On1/Digikam/etc.
- Use the Damselfly Desktop client to write the files directly to the local filesystem in the same structure as on the server.
- Export to a zip file to download and extract into the local image folder for additional editing
- Re-sync using RClone to push the images back to the collection [Future enhancement: Damselfly Desktop App will do this for you]
More information
Thanks and Credits
- Microsoft Blazor.Net for allowing me to avoid writing Javascript. ;)
- PumpkinBeth (my wife) for taking the photo that appears in Damselfly's logo, and for providing the original inspiration to build Damselfly - as well as the 600,000 photos and counting which make excellent test data!
- SkiaSharp Fast library for Thumbnail generation
- SixLabors ImageSharp Portable library for Thumbnail generation
- Drew Noakes' MetadataExtractor, for IPTC and other image meta-data indexing
- Phil Harvey's ExifTool which Damselfly uses for all of the EXIF write operations
- ZZZ Project's Entity Framework Extensions for their excellent EFCore extensions.
- MudBlazor for their excellent Blazor component library
- FaceONNX for their excellent face detection and recognition library
- Font Awesome for their Awesome icons
- Chris Sainty for Blazored Modal and Typeahead, and all his excellent info on Blazor
- Serilog.Net for logging
- Wisne for Infinite Scroll inspiration