Node项目中用images+imageinfo库给图片批量添加水印

 3909

Nodejs中怎么给图片批量添加水印?下面本篇文章给大家介绍一下Node项目中用images+imageinfo库给图片批量添加水印的方法,希望对大家有所帮助!


Node项目中用images+imageinfo库给图片批量添加水印


Nodejs给图片批量添加水印

环境准备

安装 images 库

  1. npm install images

安装 imageinfo 库

  1. npm install imageinfo


实现

本例 addimageinfo.js 与 marklogo.png 、imagest文件夹、node_modules 文件夹 在同一目录下。

含子文件也可实现


JS代码

若直接使用需修改一下信息

  1. var logomarkimg = images('./marklogo.png');//水印位置
  2. var rmimgpath = "./imagest/img/";//添加图片文件加位置
  3. var mark = "logo_";//另存图片前缀,若为""则替换原图片

完整代码 addimageinfo.js

  1. //引用文件系统模块
  2. var fs = require("fs");
  3. //引用imageinfo模块
  4. var imageInfo = require("imageinfo");
  5. //引用images模块
  6. var images = require('images');
  7.  
  8. var logomarkimg = images('./marklogo.png');//水印位置
  9. var rmimgpath = "./imagest/img/";//添加图片文件加位置
  10. var mark = "logo_";//另存图片前缀,若为""则替换原图片
  11.  
  12. function readFileList(path, filesList) {
  13.     var files = fs.readdirSync(path);
  14.     files.forEach(function (itm, index) {
  15.         var stat = fs.statSync(path + itm);
  16.         if (stat.isDirectory()) {
  17.             //递归读取文件
  18.             readFileList(path + itm + "/", filesList)
  19.         } else {
  20.             var obj = {};//定义一个对象存放文件的路径和名字
  21.             obj.path = path;//路径
  22.             obj.filename = itm//名字
  23.             filesList.push(obj);
  24.         }
  25.     })
  26. }
  27. var getFiles = {
  28.  
  29.     //获取文件夹下的所有文件
  30.     getFileList: function (path) {
  31.         var filesList = [];
  32.         readFileList(path, filesList);
  33.         return filesList;
  34.     },
  35.     //获取文件夹下的所有图片
  36.     getImageFiles: function (path) {
  37.         var imageList = [];
  38.         this.getFileList(path).forEach((item) => {
  39.             var ms = imageInfo(fs.readFileSync(item.path + item.filename));
  40.             ms.mimeType && (imageList.push(item))
  41.         });
  42.         return imageList;
  43.     }
  44. };
  45. //获取文件夹下的所有图片
  46. var photos = getFiles.getImageFiles(rmimgpath);
  47. for (var i = 0; i < photos.length; i++) {
  48.     var sourceImgpath = photos[i].path;
  49.     var sourceImgname = photos[i].filename;
  50.     var sourceImg = images(sourceImgpath + sourceImgname);
  51.     var sWidth = sourceImg.width();
  52.     var sHeight = sourceImg.height();
  53.     var wmWidth = logomarkimg.width();
  54.     var wmHeight = logomarkimg.height();
  55.  
  56.     images(sourceImg)
  57.         // 设置绘制的坐标位置,右下角距离 10px
  58.         .draw(logomarkimg, sWidth - wmWidth - 10, sHeight - wmHeight - 10)
  59.         // 保存格式会自动识别
  60.         .save(sourceImgpath + mark + sourceImgname + '');
  61. }

运行

在目录下,运行node命令

  1. node ./addimageinfo.js


查看效果


Node项目中用images+imageinfo库给图片批量添加水印

Node项目中用images+imageinfo库给图片批量添加水印


本文网址:https://www.zztuku.com/index.php/detail-11053.html
站长图库 - Node项目中用images+imageinfo库给图片批量添加水印
申明:本文转载于《CSDN》,如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐