Crates.io | graphicsmagick |
lib.rs | graphicsmagick |
version | 0.6.1 |
source | src |
created_at | 2020-04-17 18:45:38.49992 |
updated_at | 2024-12-08 00:01:19.442809 |
description | GraphicsMagick binding for Rust. |
homepage | |
repository | https://github.com/jmjoy/graphicsmagick-rs |
max_upload_size | |
id | 231269 |
size | 339,947 |
GraphicsMagick binding for Rust.
Require graphicsmagick
, libgraphicsmagick
, clang
and libclang
.
In Deepin/Ubuntu/Debian, you can install these by:
sudo apt install graphicsmagick libgraphicsmagick1-dev
sudo apt install llvm-dev libclang-dev clang
Before build, please check the GraphicsMagickWand-config
is executable,
or specify the environment variable GRAPHICS_MAGICK_WAND_CONFIG
correctly.
Support and tested GraphicsMagick version: >= 1.3.20
.
If you want to use higher version functions, you should specify features in Cargo.toml
like:
features = ["v1_3_36"]
GraphicsMagick
supports OpenMP if you are compiling with OpenMP-enabled cc
, you can set the environment variable
OMP_NUM_THREADS
to limit the number of threads or set OMP_DISPLAY_ENV=TRUE
to display the OpenMP info when
running the application.
Read http://www.graphicsmagick.org/OpenMP.html for details.
Simple resize example:
use anyhow::Context;
use graphicsmagick::{initialize, types::FilterTypes, wand::MagickWand};
use std::path::PathBuf;
fn main() -> anyhow::Result<()> {
// This function should be invoked in the primary (original) thread
// of the application's process, and before starting any OpenMP
// threads, as part of program initialization.
initialize();
let path = PathBuf::from(env!("CARGO_MANIFEST_DIR"))
.join("..")
.join("meta")
.join("GraphicsMagick-Logo.webp");
let path = path.to_str().context("get image path failed")?;
let mut mw = MagickWand::new();
mw.read_image(path)?
.resize_image(100, 100, FilterTypes::UndefinedFilter, 1.)?
.write_image("/tmp/output.webp")?;
Ok(())
}
MIT.