1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63
//! # tiny_tiff
//!
//! `tiny_tiff` is a wrapper for the TinyTIFF C++ library. It enables easy reading and writing of
//! uncompressed TIFF images with uint, int, or float data types.
//!
//! DEPENDANCIES
//! ============
//!
//! ## Unix
//!
//! - `git clone https://github.com/ryn1x/TinyTIFF.git`
//! - `cd TinyTIFF`
//! - `mkdir build`
//! - `cd build`
//! - `cmake ..`
//! - `make`
//! - `sudo make install`
//!
//!
//! ## Windows
//!
//! - `git clone https://github.com/ryn1x/TinyTIFF.git`
//! - `cd TinyTIFF`
//! - `mkdir build`
//! - `cd build`
//! - `cmake ..`
//! - `cmake -DCMAKE_WINDOWS_EXPORT_ALL_SYMBOLS=TRUE -DBUILD_SHARED_LIBS=TRUE -G "Visual Studio 15 2017 win64" ..`
//! - build generated ".sln" file with visual studio
//!
//! SYNOPSIS
//! ========
//!
//! ```
//! extern crate tiny_tiff;
//!
//! use tiny_tiff::reader;
//! use tiny_tiff::writer;
//!
//! // read
//! let tiff = reader::open("./tests/test_data/cell32.tif").unwrap();
//! let bits = reader::bits_per_sample(tiff, 0);
//! let width = reader::width(tiff);
//! let height = reader::height(tiff);
//! let size = width * height;
//! let mut buffer: Vec<f32> = vec![0f32; size as usize];
//! reader::sample_data(tiff, &buffer, 0);
//! reader::close(tiff);
//!
//! // manipulate
//! for px in &mut buffer {
//! *px += 42f32;
//! }
//!
//! // write
//! let tiff = writer::open("./tests/test_data/cell32_example.tif", bits, width, height).unwrap();
//! writer::write_image_float(tiff, &buffer);
//! writer::close(tiff, "cell32 + 42!");
//! ```
extern crate libc;
pub mod reader;
pub mod writer;