DatView
(Dat)a (View)er software
data:image/s3,"s3://crabby-images/c0f23/c0f23b3a57ff6d9e5033197c25e7918ca0137995" alt="Datview_Logo"
Python GUI software for folder browsing and viewing text, image, Cine, and HDF files
Motivation
In synchrotron facilities, where Linux OS and open-source software are the primary tools,
users often need to switch between multiple GUI applications for different tasks such as
Nautilus for folder browsing, NeXpy or HDFView for viewing HDF files, Gedit for
text files, and ImageJ for image viewing.
This separation of tools is inconvenient, especially since many users are not familiar
with the Linux OS. DatView provides a unified GUI for all these tasks, improving
efficiency and user experience. DatView runs across multiple operating systems.
Design Philosophy
DatView has been developed following a few key guidelines:
- Minimize dependencies and the codebase.
- Maximize functionality and maintainability.
With these principles in mind, DatView was built using only a few dependencies:
- H5py, Hdf5Plugin, Pillow, and Matplotlib.
- The GUI components are built with Tkinter, a built-in Python library.
- Matplotlib widgets are used to enhance interactivity while keeping the code minimal.
For distributing the software through Pip and Conda, the software is structured based on
the RUI (Rendering-Utilities-Interactions) concept, which is a user-friendly
adaptation of the MVC design pattern.
For the easiest usage, a monolithic codebase (datview.py, approximately 1,650 lines)
is provided, allowing users to simply copy the file and run it without needing to install
the software through Pip or Conda, provided that their Python environment includes H5py, Pillow,
and Matplotlib.
Features
-
Fast folder browsing and file listing. Note that the GUI appears more visually
refined on Windows OS compared to the demonstration below, which was captured on Red Hat Linux.
data:image/s3,"s3://crabby-images/127aa/127aadaea3c6b75c0e72d7caf9f9edf153f16c91" alt="Fig1"
-
Viewing metadata in an HDF file or Cine file. Displaying the contents of a text file.
data:image/s3,"s3://crabby-images/3a79a/3a79ab238faa47d5a8b8f8cf9246965324badce8" alt="Fig2"
-
Interactive viewing 1D, 2D, or 3D datasets in an HDF file. Supports ROI zooming, line profile
selection, contrast adjustment, and slicing along axis 0 and 1
data:image/s3,"s3://crabby-images/b8d61/b8d61716d0fd9b15d7a722bc0ac0dc5fb1ee1f03" alt="Fig3"
-
Interactive viewing of TIF files in a folder or frames of a Cine file.
-
Interactive viewing of an image (JPG, PNG, TIF,...)
-
Viewing 1D or 2D datasets of an HDF file in table format.
-
Opening multiple interactive viewers simultaneously.
-
Saving a 2D array in a 3D dataset of an HDF file or Cine file as an image.
-
Saving a 1D or 2D dataset of an HDF file or the current line profile as a CSV file.
data:image/s3,"s3://crabby-images/f6e24/f6e24a81153fbd470c721cfde1b6be120a4ceb2b" alt="Fig4"
Installation
Install Miniconda or Anaconda, then
open a Linux terminal or the Miniconda/Anaconda PowerShell prompt and use the following commands
for installation.
Using pip:
pip install datview
Using conda:
conda install -c algotom datview
Once installed, launching Datview with
datview
Using -h for option usage
datview -h
Installing from source:
- If using a single file:
- Copy the file datview.py. Install python, h5py, pillow, and matplotlib
- Run:
python datview.py
- If using setup.py