Skip to main content

FicImage is an application designed to enhance the reading experience of FicHub epubs.

Project description

FicImage is an application designed to enhance the reading experience of FicHub epubs. With FicImage, users can easily add missing images to their FicHub epubs, bringing the stories to life with vibrant visuals. This user-friendly tool allows readers to fully immerse themselves in their favorite fan fiction stories and enjoy them in a whole new way.

How to Use

Installation with PIP

  1. Install FicImage using pip install FicImageScript.

  2. After installation, run the program using ficimage -p path/to/epub -c path/to/ficimage/json where path/to/epub is the path to the FicHub epub you want to add images to and path/to/ficimage/json is the path to a file called ficimage.json . ficimage.json lets you configure FicImage. See more in the configuration section below.

(virt) nonso@HPEnvy:~/Documents/Code$ ficimage -h
 usage: main.py [-h] [-p PATH_TO_EPUB] [-c CONFIG_FILE_PATH] [-d] [-v] [-r RECURSIVE]

 Update a FicHub epub file with images.

 options:
   -h, --help            show this help message and exit
   -p PATH_TO_EPUB, --path_to_epub PATH_TO_EPUB
                         The path to the FicHub epub file.
   -c CONFIG_FILE_PATH, --config_file_path CONFIG_FILE_PATH
                         The path to the ficimage.json file.
   -d, --debug           Enable debug mode.
   -v, --version         Prints out the current version and quits
   -r RECURSIVE, --recursive RECURSIVE
                         This will update all files in the directory path given and its subdirectories

Image Support

FicHub creates EPUB 3.3 files, which means that FicImage only save images in the following file format:

  • JPEG

  • PNG

  • GIF

  • WEBP

  • SVG

See the Core Media Types Section of the EPUB Version 3.3 Specification for more information.

While FicImage can save SVG images, it can not compress them because SVGs are not supported by Pillow.

FicImage uses Pillow for image manipulation and conversion.

By default, FicImage will try and save all non-animated images as JPEGs.

The only animated images that FicImage will save are GIFs and WEBPs.

FicImage does little to no processing on GIFs and WEBPs images. This is to avoid breaking the animation.

If FicImage can not download an image, it leaves the image url paragraph the same way it met it.

To configure image support, you will need to create a file called ficimage.json. See the section below for more information.

Configuration

FicImage comes with a configuration file that allows you to customize the program to your liking.

The configuration file is in the JSON file format and contains the following options:

  • compress_images: A boolean that tells FicImage whether to compress images. This is only supported for jpeg and png images.

  • default_image_format: A string that tells FicImage what default format to convert and save images in. This is only supported for jpeg and png images.

  • max_image_size: An integer that tells FicImage the maximum size of an image in bytes. If an image is larger than this value, FicImage will compress it.

FicImage checks for a configuration file in the given directory path. If no directory path is given, FicImage checks the current directory and then the Operating System’s home directory.

If it does not find one, it uses the following defaults:

{
    "compress_images": true,
    "default_image_format": "JPEG",
    "max_image_size": 100000
}

Note: The compress_images key is a boolean and can only be true or false. Booleans in JSON are written in lowercase.

Note: If the default_image_format key does not exist, FicImage will default to jpeg. The two image formats are jpeg and png. The default_image_format key is case-insensitive.

Note: The compress_images key tells FicImage to compress images. This is only supported for jpeg and png images. This also goes hand-in-hand with the max_image_size key. If the compress_images key is true but there’s no max_image_size key, FicImage will compress the image to a size less than 1MB (1000000 bytes). If the max_image_size key is present, FicImage will compress the image to a size less than the value of the max_image_size key. The max_image_size key is in bytes.

If compress_images is false, FicImage will ignore the max_image_size key.

Warning: Compressing images might make the image quality worse.

Warning: max_image_size is not a hard limit. FicImage will try to compress the image to the size of the max_image_size key, but it might not be able to compress the image to the exact size of the max_image_size key.

Warning: max_image_size should not be too small. For instance, if you set max_image_size to 1 000, FicImage will probably not be able to compress the image to 1 000 bytes (1 KB). If you set max_image_size to 1 000 000, FicImage will probably be able to compress the image to 1 000 000 bytes (1 MB).

Warning: FicImage will not compress GIFs or WEBPs, that might damage the animation.

TODO

  • ☒ Improve logs

  • ☐ Conversion to other FicHub supported formats from ePub.

  • ☐ More testing

Contributing

Fork this repo and get started!

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

FicImageScript-2.1.0.tar.gz (11.4 kB view details)

Uploaded Source

Built Distribution

FicImageScript-2.1.0-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file FicImageScript-2.1.0.tar.gz.

File metadata

  • Download URL: FicImageScript-2.1.0.tar.gz
  • Upload date:
  • Size: 11.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for FicImageScript-2.1.0.tar.gz
Algorithm Hash digest
SHA256 a4c6a7cb12fd4ea1375fb98c13ba7d79e61fe3cd7aa6591fd2d348d443be00b2
MD5 fc57f2576476b21610fdb781b78a911c
BLAKE2b-256 6d0c145995247f8ef2626749d45e66e5b284f97ad044ce9742cddca7f7326a25

See more details on using hashes here.

File details

Details for the file FicImageScript-2.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for FicImageScript-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 87028e81ce1278c05c19c0b3787cfb905cfaaf1e6e715873c55cfb16f0851284
MD5 b1dd08de6255a0096ceb33580e82ebac
BLAKE2b-256 4cb6f8b03b82682bbcb42625c1b1241b521867c9694e32470d51d7b6c5f3c14e

See more details on using hashes here.

Supported by

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