Skip to content

Releases: bluescan/tacentview

Packaging

09 Sep 23:36
Compare
Choose a tag to compare

Overview

This is point release. Better support for XDG has been added so that a NIX package can be deployed. There is now also the ability to create a portable release for Linux in tgz format. The portable tgz release does not integrate itself into your distribution -- no modifications or additions to usr/share or other shared directories. This release also includes a fix for displaying palettized PNG images that have transparency.

Full Changelog: v1.0.45...v1.0.46

Raw Import, Natural Sorting, XDG, and Cube mipmaps.

26 Aug 07:33
Compare
Choose a tag to compare

Overview

This release features the ability to import raw pixel data from unknown filetypes. If you have an image file but do not know its format, or you know you have a file with only pixel-data inside it, you can now import it into Tacent View. The import functionality supports a large number of pixel formats and can show a live preview to help you get things right.

Optional Natural sorting of files in the thumbnail and file dialogs is available. This is now the default for both dialogs. Natural Sorting is often the order you see files in your OS shell when using a file explorer. It will, for example, make sure numbers in filenames are sorted correctly even if there are leading zeroes or hyphens.

When displaying the different faces of cubemaps in Tacent View it used to only display the top (level 0) mipmap. Now you can select which cupemap mipmap level to display and quickly loop through all the faces and mipmap levels with the scrubber.

In Linux the default location to store cache and config files used to be a hidden directory called .tacentview. This is generally not considered good practice and there is a specification called XDG Base Directories that suggests better places to put things as well as allowing users to override the default locations. Tacent View now respects this specification.

Raw Import

In this example we are importing raw pixel data from an unknown file that we think may store pixel data. It looks like the 5-bit exponent floating-point format is correct. The image is skewed because the width is supposed to be 1280 rather than 1279 and we are getting the Data Shortage warning because the height is set too high (720 is correct).

image

The Data Shortage warning is displayed whenever there aren't enough bytes in the input file given the width, height, offset, mipmap mode, and pixel format currently being used. Example files are available in the github repo. To open the dialog hit Ctrl-Ior access it from the File menu.

Natural Sorting

The following screenshot highlights the difference between Natural sort and normal File Name sorting. The latter is based on the character encoding being used (usually some extension of ASCII like UTF-8) and often does not give desireable results. The Open File dialog has Natural turned OFF and results in the frames being out of order while the Thumbnail View has Natural turned ON and all the frames are ordered sequentially.

image

With Natural Sorting groups of adjacent digits are treated as single numbers so the files are ordered in the way you'd expect. The sorting code implementation was provided by github user ClangPan. There is a discussion of this issue at codinghorror that is still relevant.

Cubemap Mipmaps

KTX, PVR, and DDS files are all able to contain cubemaps. Additionally all three formats support mipmaps for each of the 6 cubemap faces. Tacent View can now display any desired mipmap level for any particular face. The scrubber lets you loop through all the faces/mipmaps.

CubeMipmaps

Base Directories

This release follows the XDG Base Directories Specification for Linux distributions. The .tacentview hidden folder in the home directory is no longer used. If you want to keep your old config file just copy it into ~/.config/tacentview. If you don't, feel free to delete the directory at your discretion. Additionally the cache files needed for fast thumbnail loading are now stored in ~/.cache/tacentview. These are the default locations for these files and users are free to override the XDG environment variables for the config and cache directories as they see fit. As documented at freedesktop.org these environemnt variables are $XDG_CONFIG_HOME and $XDG_CACHE_HOME.

Summary of Changes

  • Updated LibKTX to v4.3.2.
  • Fix compile issue with newer versions of GCC. Specifically GCC 14.1.1 required algorithm to be included by the colour quantization implementations.
  • Updated the bcdec library to v0.97. This library decodes BC pixel formats.
  • Import Raw supports width, height, mipmaps, and data-offset.
  • Build instructions are now in the Wiki rather than the homepage README.
  • Raw Import pixel-format selection combo boxes. One each for Packed, Block, PVR, and ASTC categories.
  • Pixel-format selector for Import Raw dialog now calls the new combo-dropdown that supports item descriptions. Tooltips for every supported pixel format are now displayed describing the format.
  • Import Raw support for creating TIF, APNG, WEBP, TGA, PNG, QOI, or BMP images.
  • Ability to set the Colour Space when importing a raw image.
  • Ability to undo premultiplied-alpha when importing a raw image.
  • Live-update allows parameters to be modified on-the-fly in the Import Raw dialog. Results are displayed immediately.
  • Results message displayed when either live-update or the Import button is pressed in the Import Raw dialog.
  • Support Reverse Rows in the Import Raw dialog.
  • Read the colour profile for all loadable filetypes so it can be displayed in the details overlay. Not all image files store this info so for some cases a best-guess is made. QOI files do, however, store this information and it is now displayed correctly.
  • Saving QOI files now sets the colour-space correctly.
  • Sorting by modification-time or file-size wasn't respecting the descending sort order. This is now fixed.
  • Updated the DDS loader to support loading of all mipmaps when the surface is a cubemap.
  • Support display of cubemap mipmaps in KTX, KTX2, DDS, and PVR files.
  • Viewer now uses 3 clearly defined directories. The location and exact names of the directories depend on packaging mode and platform.
    1. Assets for static assets that need to be present like icons and button images.
    2. Config for user configuration file that should persist between installs, and
    3. Cache for transient files that speed things up and may be deleted.
  • Snap builds now store the config file in a location that will persist across updates.
  • Updated snap build to use the Core24 virtual machine.

Full Changelog: v1.0.44...v1.0.45

Ping, Paste, and Profile

07 Jun 00:59
Compare
Choose a tag to compare

Overview

This release features improved PNG file support and the ability to copy and paste only specific channels to/from the system clipboard. Additional improvements include extended character support for command-line arguments, better rename dialog behaviour, an additional alternative user profile, and a number of bug fixes.

PNG

PNG files that have 16 bits per component are now supported. These may be loaded as well as saved. A 16-bit PNG refers to 16 bits per channel so the there is a lot of colour information -- more than any current monitor can discern. 12-bit monitors are exceedingly rare, while 10-bit are becoming more mainstream. 16-bit PNG files are either 48 or 64 bpp (bits per pixel) depending on whether an alpha channel is present. Tacent View can now load and save these files albeit it displays them at lower colour precision. While Tacent View is now capable of creating higher-precision frame buffers, the images are currently displayed at 24-bit.

image

Copy (Ctrl-C)

When copying to the clipboard the channel filter dialog may now be used to specify which channels are copied. A copy fill-colour is used when copying to the clipboard -- unselected channels will be filled with the corresponding component of this RGBA colour. If channel-intensity is selected in the channel filter dialog, the fill-colour is not used since the chosen intensity channel is spread into the RGB of the opaque clipboard image -- creating a grey-scale intensity clipboard image. The chosen intensity channel may be one of R,G,B, or A.

image

Paste (Ctrl-V)

When pasting the clipboard there are two options: either have Tacent View create a new image, or paste into the current image. When pasting into the current image only the selected channel filters (RGBA in the channel filter dialog) are updated. If intensity is selected, the intensity of the pasted image is copied into the selected intensity channel -- which may be one of R, G, B, or A.

image

When pasting an image of a different size than the current image, an anchor position may be set to control where the pasted image will be placed. The default is to paste at the top-left of the current image.

image

Alternative Profile

Pressing Alt-4 will enable the alternative profile. This profile has the same defaults as the main profile so is good for general usage where you might have slightly different settings. Everything that can be adjusted in Tacent View is saved so you can have different filters, slideshow-periods, paste-settings, etc in each of your profiles. The current profiles are main, basic, kiosk, and alt.

Summary of Changes

  • Allow UTF-16 command-line args in Windows. Before this it was impossibe to open files from the command-line that had extended characters in them.
  • Rename dialog now sets initial focus to the filename text box rather than the OK button.
  • Support loading and saving of 16 bit-per-component PNG files. Both 3 and 4 channel.
  • Copy/Paste specific channels only if desired.
  • Copy/Paste intensity mode.
  • Loading TGA files now respects the flip-horizontal and flip-vertical bits that may be set in the header.
  • All copy/paste preferences are now in the Behaviour tab.
  • Fixed possible crash when pasting from some applications.
  • Updated Clip Library to lastest v1.9.
  • Added ability to specify the paste anchor if image dimensions differ.
  • Support 16, 24, 32, and 64 bpp images pasted from the clipboard.
  • Support horizontal and vertical roll when pasting from the clipboard.
  • Added a new alternative profile for everyday use.
  • Ability to request 8, 10, 12, and 16 bit-per-component frame buffers. Default is now 10-bit. See Preferences->Interface.
  • Fix row-reversal default when loading PNG files.
  • Fix issue with strict loading of PNG files. The strict preferences setting is now respected.

Full Changelog: v1.0.43...v1.0.44

Pixel Formats and PowerVR

02 Jan 11:26
Compare
Choose a tag to compare

Overview

This release features experimental support for PowerVR (PVR) files, output filename formatting using the CLI, support for more pixel formats including some exotic ones, UI improvements like better control over visibility of on-screen buttons, consistent display of long filenames, and tweaks to the preferences and levels dialog windows.

PVR support uses a custom parser similar to the current DDS and KTX parsers. It is capable of opening and reading PVR V1 V2 and the latest V3 files. All BC, ETC, EAC, and ASTC pixel formats are supported. PVRTC1 at 4 BPP and 2 BPP is supported. Most packed formats (adjacent RGBA bits in some defined order) are supported including HDR floating point formats, shared-exponent E5R9G9B9uf, and B10G11R11uf. The screenshot below shows Tacent View with a R8G8B8M8 PVR3 file. The max-range was saved as 8 so the value set in the UI is causing under-exposure.

Screenshot_2024-01-01-17-29-10_R8G8B8M8

Cubemap, mipmap, and PVR files with orientation meta-data are supported. The PVR feature overall is still considered experimental because PVRTC2 (not to be confused with PVRTC1 at 2bpp), the YUV formats, and volume textures are not supported yet.

The newly added pixel-formats include RGBM, RGBD, ERGB999, RGB111110, PVR4BPP, PVR2BPP, and any previously missing 16 and 32-bit-per-component integral R, RG, RGB, and RGBA formats. DDS and KTX containers leverage the new pixel-formats if possible.

In addition to PVR support, improvements to the UI have been made including Cyrillic glyphs, better display of filenames in the thumbnail view (by using ellipsis for long names), and fixes to popup windows at various UI sizes. The details panel displays channel-type information (UNORM, SNORM, UINT, SINT, SFLOAT, UFLOAT) and, if present, the alpha-channel mode. The levels modal updates the mid-point value live when in auto-mid-point mode.

Most of the upgrades in this release (PVR support, additional pixel-formats, detection of channel-type/alpha-mode, etc) are inherited from the Tacent base libraries -- for this reason relevant changes made to Tacent are listed in addition to the summary for Tacent View.

Summary of Changes

  • Support for PVR V1,V2, and V3 files. PVR properties popup supports gamma-correction, exposure for HDR images, and spread-luminance.
  • PVR3 meta-data orientation loading. The new preferences option is enabled by default. Updated test suite images for PVR3 to include BC test images and images with orientation meta-data set (horizontal and vertical).
  • Combined meta-data re-orient loading option for jpg (EXIF) and pvr files into a single option. No need for them to be separate. The latest Tacent libs support EAC, ETC1/2, ASTC, BC, PVR1BPP4, PVR1BPP2, shared-exponent, short float, RGBM, and RGBD pixel formats. Added relevant pvr test images.
  • PVR properties now allow alternate mipmap and cubemap display (T-layout).
  • Details panel now shows both alpha-mode and channel-type if the current image supplies this information. Added tooltip text for both new fields. Moved tooltip for colour-profile to the Colour Profile field instead of the title field.
  • Refresh whole directory with Shift-F5 or Ctrl-F5. Remappable.
  • Better names for tabs in the preferences window. Added hide-on-screen-controls to interface tab. By default Basic and Kiosk profiles hide the on-screen controls. On-screen controls may be set to always, never, or auto.
  • CLI now supports simple filename manipulation including prefix, suffix, and string replace. The relevant command is --outname and examples have been added to the website along with help text (-h) to describe the syntax for the option.
  • Cleaned up more of the UI modals and made their title-bar style/sizing consistent.
  • Font glyph range now includes Cyrillic and the ellipsis Unicode code-point. Added a crop-string function to reduce a string to a specified render width based on the current font and scale.
  • Fixed the delete-file and delete-file-permanently modals to support wider paths and printing of ellipsis when they are too long. In these cases hovering over the path will display the whole thing.
  • Thumbnail view now uses the string-crop render-width function to produce consistently sized filenames. If too long to fit the whole thing, an ellipsis is used.
  • Tacent pixel-format names now match the in-memory footprint.
  • Include modification time in the hash computation that determines if something changed when focus is regained.
  • Fix overwrite-file and overwrite-multiple-files dialogs so that paths and filenames do not over-extend the dialog window beyond the right button. Uses the text-cropping functionality that may add an ellipsis if necessary.
  • Levels Window. PowerMidGamma, AutoMidPoint, and LogarithmicHisto are now saved to config and persist between runs. When AutoMidPoint is on: a) the mid-point slider now remains visible, b) the mid-point slider can continue to be used for manual adjustments and is only 'auto-set' when the black or white points are adjusted, and c) will 'push' the extents of the black and white points when adjusted. In non-auto mode, the midpoint is constrained to the black/white points and will not affect them.
  • If ellipsis displayed for overwrite files you can now hover to see the full file name or directory path.

Full Changelog: v1.0.42...v1.0.43

Relevant Tacent Library Changes

This release introduces experimental support for loading and decoding PowerVR images, extends pixel-format support for image container formats (DDS, KTX, and PVR), adds new packed floating-point classes, improves the drive-information API (especially for removeable media), updates the PNG loading library, and allows saving/loading of image meta-data to disk. Any bugs and improvements listed below have been automatically inherited by Tacent View.

Features

  • Saving and loading of image tMetaData to/from tChunk binary format.
  • Meta-data focal length is in mm.
  • Updated libpng from 1.6.37 to 1.6.40.
  • Detection of JPG/JFIF content inside a PNG file. Some phone software generates these 'invalid' images and now they will load.
  • Better handling of corrupt tga files that used to cause a buffer overrun. We now check that we're in bounds.
  • PVR supprt for V1, V2, and V3 files.
  • Consistent naming of all pixel-formats.
  • Introduced satellite information for channel-type (UNORM, SNORM, UINT, UFLOAT, etc).
  • Packed small-float classes. F11F11F10 and F10F11F11 are 32-bit packed formats supporting 2xE5M6 and 1xE5M5 floats (no sign bit). M9M9M9E5 and E5M9M9M9 are 32-bit packed formats supporting 3xE5M9 (3xF14) but with a shared 5-bit exponent and no sign bit. Because of the shared exponent this format does not used normalized mantissa (always denorm).
  • Support for exotic pixel-formats including PVRBPP2, PVRBPP4, R11G11B10uf, E5R9G9B9uf, R8G8B8M8, R8G8B8D8 plus integral types R16, R16G16, R16G16B16, R16G16B16A16 and their 32-bit-per-component counterparts. Where supported these formats may be contained by DDS, KTX, KTX2, and PVR (V1, V2, V3) files.

Improvements and Fixes

  • Unit test for saving and loading meta-data to a tChunk file. Added operator== and != for both tMetaDatum and tMetaData.
  • Deborder picture function now returns false if there is no change.
  • Consistent use of load params across all image loaders that need them. JPG and PNG now have params instead if just a set of flags.
  • The naming for the PVRTC pixel formats is finalized so they are unambiguous. For version 1: "PVRBPP4", "PVRBPP2", "PVRHDRBPP8", and "PVRHDRBPP6". For version 2: "PVR2BPP4", "PVR2BPP2", "PVR2HDRBPP8", and "PVR2HDRBPP6". Updated the remaining pixel-format query functions and added a tIsLDRFormat in addition to tIsHRDFormat. Note that for the ".pvr" container format (as opposed to the pixel format) it comes in 3 versions (V1 V2 V3) but all use the same "pvr" extension.
  • Fixed issue where tGetDriveInfo was not filling out the drive letter correctly.
  • The state of tImageDDS and specifically the IsValid call could give bad results if a file load wasn't attempted. The Results bitfield is now a more general current State and the IsValid works for all cases. The fix has been propagated to tImageKTX and tImagePVR.
  • If possible, the DDS loader will now set the channel-type - modern dds pixel formats allow it to be determined in some cases.
  • Channel-type determined for VK packed formats in KTX2 files.
  • ICO files always considered to be in sRGB colour profile.
  • Now handle both unsigned and signed versions for BC4 and BC5. These new ATI1 and ATI2 variants are supported in dds, ktx, ktx2, and pvr files. All BC formats exportable by PVRTexTool are now loadable.

Full Tacent Changelog: bluescan/tacent@v0.8.16...v0.8.17

High DPI

01 Oct 10:12
Compare
Choose a tag to compare

Overview

This release features numerous usability updates. The most significant improvement is support for high-resolution screens by reading the OS desktop manager scale setting. This allows 4K monitors to be used without eye-strain due to tiny text. The smallest UI size setting, called nano, is still present and represents about a 75% OS scale -- for those that value screen real estate and have perfect vision. The screenshot shows the font and widget sizes at an OS scale of 250%. It's a little hard to tell because the image is presented downscaled from 2255x1505.

image

Additional usability improvements include the ability to change drives using only the navigation bar (previously you needed to use the file-open dialog), display of the image file name in the nav-bar while in fullscreen mode (the window title bar is not visible in fullscreen, so it couldn't be seen at all), general cleanup of widget alignment/size for many of the dialogs, and the ability to print reference usage examples from the command-line.

Summary of Changes

  • Fixed TAB characters interfering with CLI help-text display.
  • Saving a TGA allows you to override the bits-per-pixel. Normally it is set to auto (decide based on image opacity) but now you can override it forcing 24 or 32 bpp.
  • All CLI examples available from the command-line. Optional argument to generate markup-ready formatting of all examples.
  • Fixed some example descriptions including the contact-sheet description.
  • 8 UI sizes implemented each using their own area of the font atlas. The sizes are called: nano, tiny, small, moderate, medium, large, huge, and massive. The auto setting will automatically determine the correct size based on the OS scale setting. If the scale is adjusted, the viewer will automatically readjust when it gains focus. This works for both Linux and Windows.
  • Separated the output log from the bottom nav-bar. It didn't belong there. The output log is now a separate popup.
  • All dialogs, menus, overlays, and popups cleaned up and support the new UI sizes. This included cleanup of the crop popup and the contact-sheet modal, both of which needed it.
  • Updating the UI size using Shift+/- (or whatever you have bound those operations to) will kick it out of auto mode.
  • Startup speed optimization by loading only the single current font-size. Subsequent UI size modifications during the session will cause the other font atlases to be loaded.
  • Nav-bar now supports changing to a different drive letter on Windows. The '/' directory is considered the parent of all logical drives.
  • Fixed an issue where the nav-bar sub-directory combo would display an unneeded scrollbar at some UI sizes.
  • Both nav-bar and file dialog no longer display drives on Windows that are not ready. This matches Windows Explorer behaviour.
  • In fullscreen mode the current image file name is displayed in the nav-bar on the right since the window title-bar is not visible. There is a display preferences option to display it all the time.

Full Changelog: v1.0.41...v1.0.42

Sort and Shuffle

19 Aug 14:13
Compare
Choose a tag to compare

Overview

This release featuress sorting images by meta-data, shuffle mode for slideshows, fill-colour for contact-sheet generation, numerous command-line improvements including exposure controls for HDR images, and a new kiosk profile.

Sorting by Meta-Data

There are many new sorting options. The sorting keys with an asterisk denote they are stored in image meta-data (JPG EXIF for example). The last item in the dropdown is shuffle which will present the images randomly sorted. To open the thumbnail view where these properties are set, just press the 'T' key. Like all key bindings, it may be modifed from this default.
image

Slideshow and Kiosk

The slideshow settings now include the ability to auto-start, set the sort order directly, and auto-reshuffle.
image
The three different profiles (main, basic, and kiosk) are accessed using Alt-1, Alt-2, and Alt-3. These shortcuts can be re-assigned if desired. The default settings for kiosk profile include being in fullscreen mode with a shuffle slideshow auto-started for you. You may launch Tacent View from the command-line in any profile by calling tacentview --profile name. To launch in the the kiosk profile that would simply be tacentview --profile kiosk.

Contact Sheet Fill

This image shows the contact-sheet (flipbook) parameters dialog. Note that only if there are more page slots than input images does the fill-colour option present itself.
image

Command Line Improvements

Specifying multiple image types for both the input and output is now possible. For example, to convert PKM and JPG images to PNG and BMP:

tacentview -c --in pkm -i jpg -o png --out bmp

This may be written more concisely with comma-separated lists:

tacentview -c -i pkm,jpg -o png,bmp

Output parameters can also be specified more concisely than before. Here is an example that specifies output parameters for GIF files. It takes in a manifest list for what files and directories to process:

tacentview -c @manifest.txt --out gif --outGIF bpp=2,qan=neu,alp=120

The --outGIF is optional and specifies any non-default parameters for creating the GIFs. In this case a 2-bit (4 colour) palette is used, the neu algorithm is used for colour quantization, and the transparency threshold is 120. There are more options for GIF output not shown here including things like loop behaviour, frame duration, etc.

Many image formats have additional load parameters that may be specified. Here we adjust EXR exposure while loading.

tacentview -c --inEXR gamma=1.8,expo=3.5

This specifies a gamma-correction of 1.8 (default is 2.2) and an exposure value of 3.5. Exposure ranges from -10.0 to 10.0 with the neutral default being 1.0. For EXR files additional load parameters, not shown here, include defogging (defog), and adjusting knee values (white and middle points) using knee-low (knelo), and knee-high (knehi).

Extensive information on using Tacent View from the command line is available here: https://bluescan.github.io/tacentview/cli.html

Summary of Changes

  • Image meta-data (EXIF), if present, is now stored cached along with the thumbnail/preview data.
  • Images may be sorted by meta-data. Sorting keys include: latitude, longitude, altitude, roll, pitch, yaw, speed, shutter speed, exposure time, F-Stop, ISO, aperture, orientation, brightness, flash, focal length, time photo taken, time photo modified, camera make/model, and description.
  • Random shuffle for slideshow with option to automatically reshuffle after every loop.
  • The thumbnail-view was inconsistently called "Content View" in some modules. It is now consistently knows as "Thumbnail View". The default key-binding is now the 'T' key. Tile has been moved to 'Ctrl-T'.
  • Some png files in the wild actually contain JPG/JFIF data inside. If strict loading is off (the default) these files will now load in Tacent View. If strict is enabled, they won't.
  • CLI mode now allows load parameters to be set for any image type that supports them. This allows things like exposure control from the CLI. For example, loading an ASTC image allows colour profile, gamma-correction mode, gamma, and exposure/tone to be set. EXR load parameters incude gamma, exposure, defog, knee-low, and knee-high. Other image types with load parameters include KTX, KTX2, DDS, JPG, and HDR (Radiance) files.
  • Respect early-exit for CLI post operations.
  • Fix CLI issue with GIF palette size specification.
  • Reworked how output paramaters are specified in the CLI. The newer syntax a) matches in the input param syntax, and b) allows only those parameters you want to override to be set. This was an issue before for types like GIF that have a lot of options.
  • A corrupt tga file that doesn't contain enough content for the header and image data could cause an exception. We now check that we're not reading beyond what is loaded for both the header and the data.
  • Added a new kiosk profile. There are now 3 profiles: main, basic, and kiosk. They can all be used any way you like -- the difference between them is the default settings. For the kiosk profile it starts in shuffle mode, auto slideshow-play is on, and auto-reshuffle is on.
  • Fullscreen mode used to be a global setting. It is now a per-profile setting. By default the kiosk profile has this set to true. Other profiles (main, basic) have this set to false.
  • Added a command-line parameter to allow setting the profile. This is one of the few CLI options that affect GUI mode.
  • Fixed crash when changing profiles and in a directory that has no images in it.
  • If play pressed and you're on the last image and not looping, start at the beginning again.
  • CLI mode allows you to specify multiple output image types instead of just one. This works for normal operations as well as post-operations.
  • Support empty-page fill colour when generating a contact sheet from the command line.
  • Contact sheet generator dialog now supports user-specified fill colour for empty pages. The colour-picker only shows up if the number of pages is bigger than the number of available images. The fill colour for contact sheets has a separate entry in the config since it has a different default (transparent black). Elsewhere (rotate, resize-canvas, etc) the fill defaults to opaque black.
  • Update LibPNG to 1.6.40
  • Lots of CLI examples added to official Tacent View website.

Full Changelog: v1.0.40...v1.0.41

Post Operations

01 Jul 23:15
Compare
Choose a tag to compare

Overview

A number of operations previously only available from the GUI are available from the command line for pipeline integration or batch processing operations. This brings parity between what can be done in the GUI versus what can be done using the CLI. Specifically, combining multiple images into a single animated image and generating contact-sheets may now both be performed from the CLI. Furthermore, high-quality image quantization is now available in the GUI from the Edit menu. Previously quantization was only an option when saving palettized image formats or from the CLI.

Quantization

Image quantization (determining a reduced colour-palette) is now available for any image rather than just as a parameter when saving GIF files. The quantize operation is available from the Edit menu. In the image below there are only 16 colours being used! The quantization in this case uses the slower Scolourq algorithm with dithering turned on. The faster Wu Bipartition algorithm also yields excellent results even without dithering.

image

Post Operations

Post operations are specified in the CLI using --po opname[arg1,arg2,...]
These are operations that take more than a single image as input and are separated out into a different pass for efficiency. The post-op pass still uses the same set of input images and it runs after all normal operations have completed. If a regular operation modifies any of the input files, the modified file(s) are used as input to the post operation. If a normal operation generates a new file not included in the inputs, the new file is not used by the post operation.

Combine

--po combine[]
Combines multiple input images into a single animated image. The output file type must support animation or be able to store multiple sub-images / pages. Details on using this command are available by passing --help as the command-line parameter.

Contact

--po contact[]
Creates a single contact sheet image (AKA flipbook) from multiple input images. You may specify the number of columns and rows or let the operation determine it automatically for you based on the number of input images. Creating contact-sheets using Tacent View handles transpareny properly. By default if an imput image has transparency, so will the contact sheet. Details on using this command are available by passing --help as the command-line parameter.

Normal Operations

Normal operations run sequentially on each input image and are specified using --op opname[arg1,arg2,...]
One additional normal operation has been added in this release to again bring parity between the CLI features and the GUI features.

Pixel

-op pixel[]
Sets the pixel at (x,y) to the colour supplied. You may specify specific channels to affect as well as offsets from the right and top edges if the input images have different sizes. Details on using this command are available by passing --help as the command-line parameter.

Summary of Changes

  • Quantize an image directly from the GUI. Quantize is available from the edit menu. The UI for the different quantize methods and parameters is now shared between the quantize modal dialog and the save GIF modal.
  • Create contact sheets from the command line interface.
  • Combine images and create animated images from the command line interface.
  • Cleaned up the gif-save, contact-sheet, extract, and multi-frame modal dialogs in the GUI so they take up less real estate.
  • Saving GIFs (both CLI and GUI) now support an auto-detect alpha channel mode. If the source image has transparency a 1-bit alpha channel will be automatically used. If the source image is opaque, all palette entries will be used for colours and the GIF will be opaque.
  • 2 more packed dds pixel formats are supported. Specifically R8G8B8 and R8G8B8A8. These are less efficient than the BGR variants, but some were found in the wild and are now loadable.
  • Fixed gif encoding. It was possible for a fully opaque image to result in a GIF with binary alpha in some circumstances.
  • Improved the warning when an image will take a long time to quantize. This is primarily when the scolorq algorithm is being used. The warning now takes the estimated running time into account and considers both the palette size as well as the image dimensions.

Full Changelog: v1.0.39...v1.0.40

Lossless Transformations

23 May 10:36
Compare
Choose a tag to compare

Overview

Two features that were notably missing have been addressed in this release: Lossless Transformations and Frame Extraction.

Lossless Transformations

Lossless transformations of JPG files are now supported. Flip (horizontal/vertical) and 90 degree rotations (CW/ACW) are supported. In some cases JPGs require a slight adjustment to image dimensions to be able to losslessly transform -- these are 'imperfect' lossless transformations and Tacent View warns you about them.

image

Frame Extraction

The second notable feature is the ability to extract individual images from a file that contains multiple. This includes extracting frames from animated formats like APNG, WEBP, and GIF, extracting pages from multi-page formats like TIFF or EXR, and extracting mipmaps or cubemap-sides from textures like KTX2 or DDS. This complements the pre-existing ability to combine individual images into an animated image -- now we can go in the other direction. Extracted frames may be saved in any of the supported save-formats and the particular frames to extract may be specified using set/interval notation. Extraction of individual images is also available from the command-line interface using the 'extract' operation.

image

Summary of Changes

The following issues and features are covered by this release:

  • Lossless 90-degree rotations and flips of JPG files.
  • Ability to extract frames from animated images, pages from multi-page images (ex. TIFF or EXR files), mipmaps from textures, and sides from cubemaps.
  • Detection of 'imperfect' lossless transformations before they are applied.
  • Sorting by type in the thumbnail viewer now works in a meaningful way by using the file extension as the sort key.
  • Ability to skip saving unchanged files in the CLI interface. --skipunchanged may be useful to use in conjunction with --op extract[]
  • Specifying frames to extract may be done from both the GUI or the CLI using interval-set notation.

Full Changelog: v1.0.38...v1.0.39

Mobile Formats

16 Apr 20:27
Compare
Choose a tag to compare

This release features improved support for common mobile image formats and encodings. A command-line operation for swizzling and setting image channels has been added. Image colour-profile detection is improved and the results are shown in the details panel.

Improvements for Mobile

  • The .atc file extension may be used for ASTC files.
  • ETC1, ETC2 (RGB, RGBA, RGB1A), and EAC (R and RG) pixel encodings are all supported.
  • PKM file viewing supported with all of the ETC-encoding variants.
  • Viewing of DDS files that contain ETC/ETC2 data.
  • Viewing of KTX/KTX2 files that contain ETC/ETC2/EAC data.
  • Auto gamma correction available for ASTC, PKM, DDS, KTX, and KTX2 files. Ability to override the correction for any of these types.
  • More robust detection of image colour profile.

Command Line

To use the new swizzle operation:

--op swizzle[rgba*]
  The swizzle operation allows you to manipulate the RGBA channels of an image
  and swap, duplicate, clear or set them. You can basically take the existing
  channels and rearrange them as you see fit.
  rgba: This is the destination mapping used by the swizzle. It is always in
        the order RGBA. It is made of the characters R, G, B, A, 0, 1, and *.
        The characters are case-insensitive so r, g, b, and a may also be used.
        The asterisk means automatic channel selection. 0 means the channel is
        set to 0 for all pixels. 1 means the channel is set to full for all
        pixels. R means the destiniation channel is taken from the original red
        channel. Similarly for G, B, and A. You do not need to specify all four
        characters if you want the remaining ones to be defaulted to their
        corresponding source channel. This is what the asterisk does.
        The default is **** which is the same as RGBA, both of which leave the
        image unmodified.
  Example 1: --op swizzle[BGR] will swap the red and the blue channels. In
  order, the new red channel gets the original blue channel, the green gets
  green, and the new blue channel gets red. This is the same as swizzle[B*R]
  and is also the same as swizzle[B*R*]. The asterisks just grab the
  corresponding original channel.
  Example 2: --op swizzle[***1] keeps the colours the same but sets the alpha
  to full for all pixels. This is the same as swizzle[RGB1].
  Example 3: --op swizzle[0] clears the red channel. Same as [0GBA] and [0***]
  Example 4: --op swizzle[GGG1] places the original green channel in the new
  red, green and blue channels. It also sets the alpha to full (opaque).

Summary of Changes

Full Changelog: v1.0.37...v1.0.38

Quality of Life

23 Mar 10:55
Compare
Choose a tag to compare

This is a QOL release that fixes a number of critical image loading issues, increases maximum image dimension to 65536x65536, and introduces a locked-aspect mode while cropping.

Image Loading

WEBP

Some animated webp files would cause a crash if frame-size didn't match the canvas-size. This is now addressed and and proper blending of each animated frame is implemented. Webp images that have transparency are often displayed with a background colour in browseers and other viewers. The background colour is stored in the webp. Tacent View now has a checkbox to use the stored background colour. The checkbox is in the properties popup while viewing webp images.

DDS

There are some dds files in the wild that do not have their header flags set correctly. If strict loading is off in the preferences (the default), these files are still loaded so long as a valid FourCC code is still present.

QOI

Qoi images were loaded and saved upside-down. This is now fixed,

Dimension

Some game engines support height-maps up to 64Kx64K in size. Tacent View has increased the maximum allowed image dimensions to match. Previously the max was 32Kx32K.

Ill-formed Images

Tacent View is now more resilient when loading ill-formed image files. Images that fail to load are simply skipped by the viewer and a warning is printed to the log (Ctrl-L).

Cropping

The biggest feature in this release is locked-aspect mode cropping. This was badly needed when cropping photos to a specific ratio. In cropping mode you can now choose to modify the crop area normally (free mode), set the cropping to a specific aspect-ratio (locked-aspect mode) , or specify the aspect ratio manually (custom mode). All common aspect-ratios are supported as presets in the aspect-mode combo box. This includes many that are for prints. Print aspect-ratios have the letter P in them.

Summary of Changes

  • Better handling of ill-formed images.
  • Loading of ill-formed DDS files.
  • Display 'Varies' for opacity in cases where animated or multi-frame images do not have the same opacity for all frames. Opaque means all pixels are opaque. Not opaque means some pixels are semitransparent.
  • Ability to override background colour for semitransparent WEBP files.
  • Increased maximum image dimensions to 65536x65536.
  • In some cases the previously opened image would fail to load when the viewer was re-opened. This could happen if the path to the last opened image file had brackets ( ). This is now fixed.
  • Fixed-aspect mode while cropping. Preset aspect-ratios include all common screen and print sizes.
  • Fixed QOI images loading in upside-down.

Full Changelog: v1.0.36...v1.0.37