<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>fiv: User Guide</title>
<link rel="stylesheet" href="stylesheet.css">
<style>
q:lang(en):before { content: "‘"; }
q:lang(en):after { content: "’"; }
</style>
</head>
<body>

<h1>fiv: User Guide</h1>

<p class="details">
<span id="author">Přemysl Eric Janouch</span><br>
<span id="email"><a href="mailto:p@janouch.name">p@janouch.name</a></span><br>
<span id="revnumber">version 0.0.0,</span>
<span id="revdate">2022-07-31</span>

<p class="figure"><img src="fiv.webp" alt="fiv's browser and viewer">

<h2>Introduction</h2>

<p><i>fiv</i> is a general-purpose image browser and viewer. This document will
guide you through the application and help to familiarize you with it.

<h2>Controls</h2>

<p><i>fiv</i> is designed with computer mice having dedicated forwards/backwards
and page up/down buttons in mind, such as SteelSeries Sensei series. Ozone Neon
series may also be mapped this way. Your experience may be degraded with other
kinds of devices.

<p>Controls should generally be accessible through the keyboard. Pressing Ctrl+?
will give you a convenient overview of all shortcuts. In addition to these,
remember that you may often use Ctrl+Tab and F6 to navigate to different groups
of widgets.

<h2>Browser</h2>

<p><i>fiv</i> normally starts in a file browser view. On the left side of the
window, you'll find your GTK+ bookmarks, mounted locations as recognized by
GVfs, an item for entering arbitrary filesystem paths or URIs, view controls,
and finally breadcrumbs leading to the currently opened directory, as well as
its descendants.

<p>You can open items in a new window either by middle clicking on them either
directly, or with the Ctrl key pressed down. Right clicking the directory view
offers a context menu for opening files, or even the directory itself,
in a different application.

<h2>Viewer</h2>

<p>The image viewer may be both entered (so long as you have a file selected)
and exited using the Enter key. This way you may easily switch between the two
modes. When using the mouse, the forwards and backwards buttons will fulfill
the same function.

<p>Double clicking the image switches full-screen view, and the mouse wheel
adjusts the zoom level.

<p>Files are iterated in the same order, and using the same filtering as in
the browser.

<h2>File formats</h2>

<p>The list of all supported file formats may be obtained by running:

<pre>
fiv --list-supported-media-types
</pre>

<p>Unless it has been turned off in your installation, you may extend it through
gdk-pixbuf modules.

<h2>Thumbnails</h2>

<p><i>fiv</i> uses a custom means of storing thumbnails, and doesn't currently
invalidate this cache automatically. Should you find out that your
<i>~/.cache/thumbnails</i> directory is taking up too much space, run:

<pre>
fiv --invalidate-cache
</pre>

<p>to trim it down. Alternatively, if you want to get rid of <i>all</i>
thumbnails, even for existing images:

<pre>
rm -rf ~/.cache/thumbnails/wide-*
</pre>

<h2>Configuration</h2>

<p>The few configuration options <i>fiv</i> has can be adjusted using
<i>dconf-editor</i>, which can be launched in the appropriate location from
within the application by pressing Ctrl+,. For command line usage, there is
the <i>gsettings</i> utility:

<pre>
gsettings list-recursively name.janouch.fiv
</pre>

<p>To make your changes take effect, restart <i>fiv</i>.

<h3>Theming</h3>

<p>The standard means to adjust the looks of the program is through GTK+ 3 CSS.
As an example, to tightly pack browser items, put the following in your
<i>~/.config/gtk-3.0/gtk.css</i>:

<pre>
fiv-browser { -FivBrowser-spacing: 0; padding: 0; border: 0; margin: 0; }
</pre>

<p>Similarly, you can adjust some of the key bindings, as per the command table
in the <i>fiv-view.h</i> source file:

<pre>
@binding-set ViewBindings { bind 'p' { 'command' (print) }; }
fiv-view { -gtk-key-bindings: ViewBindings; }
</pre>

<p>Should you want to experiment, you will find the GTK+ inspector very helpful.

<script>
var toc = '', all = document.querySelectorAll('h2')
for (var i = 0; i < all.length; i++) {
	var name = all[i].innerHTML.replace(/[^0-9a-z]/ig, '-')
	toc += '<li><p><a href="#' + name + '">' + all[i].innerHTML + '</a></li>'
	all[i].id = name
	all[i].innerHTML = (i + 1) + '. ' + all[i].innerHTML
}
all[0].insertAdjacentHTML('beforebegin',
	'<h2>Table of Contents</h2><ol>' + toc + '</ol>')
</script>