imagemagick static binaries for Mac OSX x64
When you want to write text into images, you have to pass the font explicitly.
you have to set the an environment variable to use it via spawn or cli.
// like you do in the bash:
export MAGICK_HOME= "path/to/node_modules/imagemagick-darwin-static/bin/osx/imagemagick/7.0.5-5/"
export DYLD_LIBRARY_PATH= "path/to/node_modules/imagemagick-darwin-static/bin/osx/imagemagick/7.0.5-5/lib/"
// with spawn, this can be done via the options parameter:
// child_process.spawn(command[, args][, options])
var convert_binary= "path/to/node_modules/imagemagick-darwin-static/bin/osx/imagemagick/7.0.5-5/bin/convert"
var MAGICK_HOME= "path/to/node_modules/imagemagick-darwin-static/bin/osx/imagemagick/7.0.5-5/"
var DYLD_LIBRARY_PATH= "path/to/node_modules/imagemagick-darwin-static/bin/osx/imagemagick/7.0.5-5/lib/"
var spawn = require("child_process").spawn;
var proc = spawn(convert_binary,
['/path/to/infille.jpg', '/path/to/outfile.png'],
{
MAGICK_HOME: MAGICK_HOME,
DYLD_LIBRARY_PATH: DYLD_LIBRARY_PATH
}
);
This is, because the dynamic libs are located in the lib folder inside this package. And imagemagick needs to know about this.
Use imagemagick in electron.atom applications for mac For more information about electron atom see https://electron.atom.io/
This module is installed via npm:
$ npm install imagemagick-darwin-static
Returns the path of a statically linked graphicsmagick on the local filesystem.
var imagemagick = require('imagemagick-darwin-static');
console.log(imagemagick.path);
For Windows (32 and 64-bit) please use graphicsmagic-static.
Best usage is with npm module gm
const path = require('path');
const graphicsmagick = require('graphicsmagick-static');
const imagemagick = require('imagemagick-darwin-static');
const {subClass} = require('gm');
let gm;
if (os.platform() == 'win32') {
gm = subClass({
appPath: path.join(graphicsmagick.path, '/')
});
} else {
gm = subClass({
imageMagick: true,
appPath: path.join(imagemagick.path, '/')
});
}
// then do any stuff you need
gm("/path/to/image.png").resize(150,150).write("/new/path.jpg", (err) => {
// here an example
if (err) return callback(err, null);
});
Thinks to keep in mind when packing electron apps with ASAR. Using e.g. the electron-builder, this package and as well graphicsmagick-static should be placed in the app.asar.unpacked folder. Electron builder does this automatically, because of the big binaries.
How ever, when done so, you will have to replace the path of the app.asar to app.asar.unpacked.
This could be achieved by a helper class as given:
import path from 'path';
export default class AppPaths {
static replaceAsar(path = "") {
return path.replace(".asar", ".asar.unpacked");
}
}
...
// Usage:
import AppPaths from 'WhatYouCalledTheFile';
var imagemagickPath = require("imagemagick-darwin-static").path;
let fixedPath = AppPaths.replaceAsar(imagemagickPath);
// Example for using ASAR:
var os = require("os");
var graphicsmagick = require("graphicsmagick-static");
var imagemagick = require("imagemagick-darwin-static");
var imageHandler = null;
if (os.platform() == "win32") {
gm = require("gm").subClass({
appPath: AppPaths.replaceAsar(path.join(graphicsmagick.path, "/"))
})
} else {
gm = require("gm").subClass({
imageMagick: true,
appPath: AppPaths.replaceAsar(path.join(imagemagick.path, "/"))
})
}
// then do any stuff you need
gm("/path/to/image.png").resize(150,150).write("/new/path.jpg", (err) => {
// here an example
if (err) return callback(err, null);
});