【Node.js】图片操作之“多媒体顶流”不羁的一生

「本文正在参与技术专题征文Node.js进阶之路,点击查看详情

前言

完成对Node.js的从了解到熟练的进阶这个Flag设立已久,久到去年就有它了。惊蛰已过,风暖云开,隔年的Flag是时候拿出来实现了。出去踏青or在家码字,我决定选择后者。

至少对Node.js的探索,今年能有一个完美的叹号。

目标明确

图片作为多媒体“顶流”之一,本文主要解锁node对图片处理的各种操作,同时收获乐趣和技能。

随波逐流无归处,乘风破浪济沧海

常规操作

node-images

操作图片前先介绍一下使用到的图片处理库-node-iamges,它是Node.js轻量级跨平台图像编解码库。

功能特性

  • 轻量级:无需安装任何图像处理库。
  • 跨平台:Windows下发布了编译好的.node文件,下载就能用。
  • 方便用:jQuery风格的API,简单可依赖。

安装

npm install images
复制代码

注意

  • 如果使用过程中遇到报错:dyld: lazy symbol binding failed: Symbol not found,可以查看一下node版本,node版本需要16.14.0。(问题issues

获取图片属性

  • .size([width[, height]]):获取或者设置图像宽高,如果height未指定,则根据当前宽高等比缩放;
  • .width([width]):获取或设置图像宽度,如果未指定值则获取图像宽度,否则设置图像宽度;
  • .height([height]):获取或设置图像高度,如果未指定值则获取图像高度,否则设置图像高度;
const images = require('images'); 
const width = images('compose-bg-2.jpeg').width(); 
const height = images('compose-bg-2.jpeg').height(); 
const properties = images('compose-bg-2.jpeg').size(); 
console.log(width); // 1080 
console.log(height); // 1339 
console.log(properties); // { width: 1080, height: 1339 }
复制代码

裁剪图片

裁剪图片主要用到三个API

  • images(image[, x, y, width, height]):从另一个图像中复制区域来创建图像
  • .resize(width[, height]):设置图像宽高,如果height未指定,则根据当前宽高等比缩放, 默认采用 bicubic 算法;
  • .save(file[, type[, config]]):编码并保存当前图像到 file ,如果type未指定,则根据 file 自动判断文件类型,config为图片设置,目前支持设置JPG图像质量
const images = require('images');
images(images('compose-bg-2.jpeg'), 0, 889, 1080, 450).resize(540).save('compose-bg-region.jpg');
复制代码

最终截取了原图片compose-bg-2.jpeg的底部并根据resize的值进行等比缩放生成新图片compose-bg-region.jpg

图片操作之“多媒体顶流”不羁的一生01.jpeg

合成图片

draw为node-images提供的绘制API,可以设置绘制到的图片上的位置

  • .draw(image, x, y):在当前图像( x , y )上绘制 image 图像
const images = require('images');
images('compose-bg.jpg').draw(images('compose-text.jpg'), 709, 14).save('compose-new.jpg', {
  quality: 100, //保存图片到文件,图片质量为100
});
复制代码

将图片B绘制到图片A上最终得到了合成图片,可以应用于某些加文案或者水印的场景。

图片操作之“多媒体顶流”不羁的一生02.jpg

旋转图片

  • .rotate(angle):将当前图像旋转,在参数中规定角度;
  • 介绍页面没有展示rotateAPI,单独源码中test文件中有这个API,我试验了一下,好使;
const images = require('images');
// 顺时针旋转90度
images('compose-bg-2.jpeg').rotate(90).save('compose-rotate-90.jpg', {
  quality: 100, //保存图片到文件,图片质量为100
});
// 顺时针旋转270度,即逆时针旋转90度
images('compose-bg-2.jpeg').rotate(270).save('compose-rotate-270.jpg', {
  quality: 100, //保存图片到文件,图片质量为100
});
复制代码

图片操作之“多媒体顶流”不羁的一生09.jpeg

“顶流”不一样的人间烟火

送你一颗红彤彤的心

  • 选一张图片,作为最终合成的图片的背景图;
  • 左半颗红心,使用rotate顺时针旋转90度,变成垂直状态;
  • 左半颗红心,使用draw绘制到背景图上,绘制点为(100, 200);
  • 右半颗红心,使用rotate顺时针旋转90度,变成垂直状态;
  • 右半颗红心,使用draw绘制到背景图上,绘制点为(300, 200);
  • 使用save保存最终的图片;
const images = require('images');
const bg = images('compose-bg-2.jpeg');
const left = images('compose-heart-left.png');
const rignt = images('compose-heart-right.png');
bg.draw(left.rotate(90), 100, 200).draw(rignt.rotate(90), 300, 200).save('compose-heart-new.jpg', {
  quality: 100, //保存图片到文件,图片质量为100
});
复制代码

最终合成的图片

图片操作之“多媒体顶流”不羁的一生05.jpeg

头像裁剪

  • 头像裁剪,选择一张图片,设置裁剪后宽度和高度,使用resize可以重置图片尺寸;
  • 宽度和高度可以只设置其中一项,另一项会取该项的值;
  • 设置可剪裁的最大尺寸,因为图片裁剪不可以设置比原图片更大的尺寸,否则报错;
const images = require('images');
/**
 * 可裁剪的图片最大宽高 一般不能超过原图片本身的宽高
 * @param {number} maxWidth 最大宽度
 * @param {number} maxHeight 最大高度
 */
images.setLimitMax = function (maxWidth, maxHeight) {
  images.maxHeight = maxHeight;
  images.maxWidth = maxWidth;
  return images;
};
// 设置可裁剪宽高的最大值
images.setLimitMax(800, 800);
/**
 * 头像裁剪
 * @param {string} img 需要裁剪的原图片
 * @param {number} width 裁剪后的宽度
 * @param {number} hight 裁剪后的宽度
 */
function tailorUserAvatar(img, width, hight) {
  if (width > images.maxWidth || hight > images.maxHeight) {
    throw new Error('宽高不能超过已设置的图片可裁剪宽高的最大值');
  }
  // 宽度和高度只设置一项时,另一项取该项的值
  const widthNew = width || hight;
  const hightNew = width || hight;

  // 剪裁之后图片名
  const pathName = `avatar-${widthNew}-${hightNew}.jpg`;

  // 剪裁并保存新图片
  images(img).resize(widthNew, hightNew).save(pathName);
}
tailorUserAvatar('avatar.jpg', 200);
复制代码

图片操作之“多媒体顶流”不羁的一生06.jpeg

如果设置超过原尺寸600*600的尺寸,程序会抛出错误

tailorUserAvatar('avatar.jpg', 1000);
复制代码

图片操作之“多媒体顶流”不羁的一生07.jpeg

总结

小技巧探索的差不多了,后面我会用Node开发实际项目,尽管目前业务上没有需要,但是有备无患。

康肃问曰:“汝亦知射乎?吾射不亦精乎?”翁曰:“无他,但手熟尔。”康肃忿然曰:“尔安敢轻吾射!”翁曰:“以我酌油知之。”乃取一葫芦置于地,以钱覆其口,徐以杓酌油沥之,自钱孔入,而钱不湿。因曰:“我亦无他,惟手熟尔。

猜你喜欢

转载自juejin.im/post/7077056444331196446