| Crates.io | graphicsmagick |
| lib.rs | graphicsmagick |
| version | 0.6.4 |
| created_at | 2020-04-17 18:45:38.49992+00 |
| updated_at | 2025-07-31 11:22:05.644882+00 |
| description | GraphicsMagick binding for Rust. |
| homepage | |
| repository | https://github.com/jmjoy/graphicsmagick-rs |
| max_upload_size | |
| id | 231269 |
| size | 355,120 |
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.