Skip to main content

A desktop OPDS 2.0/1.2 browser and comic downloader/streamer/reader

Project description

ComicCatcher

ComicCatcher Logo

PyPI version License: MIT

ComicCatcher is a desktop OPDS (v2.0 and v1.2) browser and comic reader. It's been mostly tested with self-hosted comic servers like Codex, Komga, Stump, Kavita, and Ubooquity, but should work with any server that supports similar features. Comics can be streamed page-by-page, or downloaded and read offline. Written in Python and runs on Linux, Windows, and macOS. ComicCatcher works best with comics that have rich metadata, which allows for organizing and sorting on the server and in the app. OPDS v2.0 servers provide a better experience.

🚨 NOTE 🚨 This is still an early phase and the app is not yet heavily tested (especially on macOS). If you encounter issues, or something doesn't make sense, please don't hesitate to report it. 🙈


✨ Features

📚 Full OPDS v2.0 and v1.2 Browsing, Designed for Comics

  • Streamed Reading Support: Read page-by-page with no download. (Depends on server support of OPDS v2.0 Digital Visual Narratives Profile (DiViNa) or OPDS-PSE (v1.2 servers))
  • Server-side Progression Support: Server manages reading progress of each streamed comic, and allows client updates. (Depends on sever support for OPDS v2.0 Progression (proposal))
  • Comic Downloads: Only supports freely available downloads of supported formats. No purchases or borrows.
  • Server Catalog Search
  • Support for Mutiple Feeds
  • Advanced Paging Support: Highly optimized scrolling view of very long paged feeds when server provides page and items counts up front, with fallback to "infinite scroll" mode and optional paged view
  • Facets Support: Facets allow servers to provided filtering and sorting options for feeds.

🏠 Local Library Management

  • Format Support: Read CBZ, CBR, CBT, CB7, and PDF files.
  • Metadata: Uses in-file metadata for display and organization.
  • Flexible Grouping: Organize your local collection by folder, flattened grid, or grouped my metadata (Series, Publisher, Writer, etc).

💬 Dedicated Comic Reader

  • Comic-First Reader Not a re-fitted e-book reader. Designed for reading comics on monitors and laptops.
  • Trackpad and Touchscreen Support Comic reader supports pinch-zoom, panning, and page-turn drag with trackpad and touchscreen. (Page-turn drag with trackpad currently not available with all Windows devices and requires Wayland on Linux)
  • Traditional Paged and Infinite Canvas (Continuous Vertical) Comic Modes
  • Dynamic Reader Background Options
  • Color Filter for Old Yellowed Paged Scans

🛸 Other

  • Advanced Keyboard Support Entire app is highly controllable with keyboard only.
  • Multiple Color Themes Dark, Light, OLED, Deep Blue, Light Blue

📸 Screenshots

Feed Selection Feed Browser Details Popup
Feed Selection Feed Browser Popup Details
Full Comic Details Reader Library
Full Comic Details Reader Transition Library Groups

🛠️ Installation

ComicCatcher can be installed across multiple platforms using package managers or standalone packages:

🪟 Windows

  • Via WinGet: Install directly from the Windows Package Manager:
    winget install ComicCatcher.ComicCatcher
    
  • Standalone Installer: Download the latest standalone .msi installer or portable .exe from the Releases page.

🐧 Linux

  • Via APT Repository (Debian/Ubuntu): Add the official static repository to install and receive automatic updates:
    # 1. Download and trust the repository GPG key
    sudo curl -fsSL https://comiccatcher.github.io/comiccatcher-apt/public.gpg.key | sudo gpg --dearmor -o /etc/apt/keyrings/comiccatcher.gpg
    
    # 2. Add the repository to your source list
    echo "deb [signed-by=/etc/apt/keyrings/comiccatcher.gpg] https://comiccatcher.github.io/comiccatcher-apt stable main" | sudo tee /etc/apt/sources.list.d/comiccatcher.list
    
    # 3. Update indices and install
    sudo apt update && sudo apt install comiccatcher
    
  • Standalone Packages:
    • AppImage: Download the portable ComicCatcher-x86_64.AppImage from the Releases page, make it executable (chmod +x), and run.
    • Debian Package: Download the standalone .deb package directly from the Releases page.

🍏 macOS

  • Via Homebrew (Cask): Add the custom tap and install the graphical app:
    brew tap comiccatcher/tap
    brew install --cask comiccatcher
    
  • Standalone DMG: Download the ComicCatcher-macOS.dmg from the Releases page and drag it to your /Applications folder.

🐍 Python (Platform Independent)

  • Via PyPI (pip):
    pip install comiccatcher
    
    Note: Requires Python 3.10+ and a desktop environment.

🚦 Quick Start

  1. Launch the app by running comiccatcher in your terminal, running via GUI (shortcut, launcher, or stand-alone).
  2. Add a Feed: Go to Settings -> Feeds and add your OPDS 2.0 server URL (e.g., http://your-server:9810/opds/v2.0/).
  3. OPTIONAL:Configure Local Library Location: Point the Library Directory in settings to where to download comics. (Defaults to ~/ComicCatcher)
  4. Browse: Browse the feed to find a comic.
  5. Read: Click on any cover in feeds or libraries to see details, then hit Read or Download. Downloaded comics will appear in the Library tab.

💡 Tips

  • Use H or Ctrl+H throughout the app for keyboard help.
  • Right-click on thumnbails for a quick details popup.
  • Right-click on anywhere in the reader view for many options.
  • Trackpad config wizard available in reader menu.

🗺️ Roadmap

Some possible enhancements:

  • Local library search/filter
  • Import server metadata locally (maybe embed in books)
  • Make feed browser aware of library contents
  • Download epubs (maybe with limited read support)

⚖️ License

Distributed under the MIT License. See LICENSE for more information.


🤖 AI Disclosure & Data Usage

This repository contains code, documentation, and commit history generated or assisted by artificial intelligence.

In the interest of preserving the integrity of future training datasets and preventing model collapse (recursive training on synthetic data), the following declarations apply:

  • Training Discouraged: We explicitly discourage the use of the content in this repository for training large language models (LLMs) or other generative AI systems.
  • Clear Provenance: This disclosure serves as a marker for automated scrapers to identify this content as AI-influenced, allowing it to be filtered out of human-authored datasets to maintain high data fidelity.
  • Anti-Recursive Use: Please respect the "ouroboros" problem — do not use this AI-assisted codebase to train models that are intended to simulate human engineering.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

comiccatcher-0.7.4.tar.gz (653.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

comiccatcher-0.7.4-py3-none-any.whl (707.8 kB view details)

Uploaded Python 3

File details

Details for the file comiccatcher-0.7.4.tar.gz.

File metadata

  • Download URL: comiccatcher-0.7.4.tar.gz
  • Upload date:
  • Size: 653.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for comiccatcher-0.7.4.tar.gz
Algorithm Hash digest
SHA256 cf3c335d4e4f9955924f12805f0d0209b7a2645dcc5458953bb2b0f20b776dea
MD5 c2a7f7d5bff4d8a8ca06d8031d35fb65
BLAKE2b-256 5c00415b01a5ab4306f23234fcd266f9fed8a3cc743e81ff419616ca45508833

See more details on using hashes here.

File details

Details for the file comiccatcher-0.7.4-py3-none-any.whl.

File metadata

  • Download URL: comiccatcher-0.7.4-py3-none-any.whl
  • Upload date:
  • Size: 707.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for comiccatcher-0.7.4-py3-none-any.whl
Algorithm Hash digest
SHA256 746cfbdf1562675b6c79cefae82f9b151d0c691f3d97ad4368c377f696aec040
MD5 a6057e887d1fc5e575a4dfab76b8a7fc
BLAKE2b-256 c558cacaa214402423aeb2ac75f878270d53bc8a464df85869d597b6496fd66b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page