• 技术文章 >web前端 >js教程

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

    青灯夜游青灯夜游2022-02-16 20:12:23转载76
    Nodejs中怎么给图片批量添加水印?下面本篇文章给大家介绍一下Node项目中用images+imageinfo库给图片批量添加水印的方法,希望对大家有所帮助!

    Nodejs给图片批量添加水印

    环境准备

    安装 images 库

    npm install images

    安装 imageinfo 库

    npm install imageinfo

    实现

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

    含子文件也可实现

    JS代码

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

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

    完整代码 addimageinfo.js

    //引用文件系统模块
    var fs = require("fs");
    //引用imageinfo模块
    var imageInfo = require("imageinfo");
    //引用images模块
    var images = require('images');
    
    var logomarkimg = images('./marklogo.png');//水印位置
    var rmimgpath = "./imagest/img/";//添加图片文件加位置
    var mark = "logo_";//另存图片前缀,若为""则替换原图片
    
    function readFileList(path, filesList) {
        var files = fs.readdirSync(path);
        files.forEach(function (itm, index) {
            var stat = fs.statSync(path + itm);
            if (stat.isDirectory()) {
                //递归读取文件
                readFileList(path + itm + "/", filesList)
            } else {
                var obj = {};//定义一个对象存放文件的路径和名字
                obj.path = path;//路径
                obj.filename = itm//名字
                filesList.push(obj);
            }
        })
    }
    var getFiles = {
    
        //获取文件夹下的所有文件
        getFileList: function (path) {
            var filesList = [];
            readFileList(path, filesList);
            return filesList;
        },
        //获取文件夹下的所有图片
        getImageFiles: function (path) {
            var imageList = [];
            this.getFileList(path).forEach((item) => {
                var ms = imageInfo(fs.readFileSync(item.path + item.filename));
                ms.mimeType && (imageList.push(item))
            });
            return imageList;
        }
    };
    //获取文件夹下的所有图片
    var photos = getFiles.getImageFiles(rmimgpath);
    for (var i = 0; i < photos.length; i++) {
        var sourceImgpath = photos[i].path;
        var sourceImgname = photos[i].filename;
        var sourceImg = images(sourceImgpath + sourceImgname);
        var sWidth = sourceImg.width();
        var sHeight = sourceImg.height();
        var wmWidth = logomarkimg.width();
        var wmHeight = logomarkimg.height();
    
        images(sourceImg)
            // 设置绘制的坐标位置,右下角距离 10px
            .draw(logomarkimg, sWidth - wmWidth - 10, sHeight - wmHeight - 10)
            // 保存格式会自动识别
            .save(sourceImgpath + mark + sourceImgname + '');
    }

    运行

    在目录下,运行node命令

    node ./addimageinfo.js

    查看效果

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    更多node相关知识,请访问:nodejs 教程

    以上就是Node项目中用images+imageinfo库给图片批量添加水印的详细内容,更多请关注php中文网其它相关文章!

    声明:本文转载于:csdn,如有侵犯,请联系admin@php.cn删除
    专题推荐:Nodejs 图片添加水印
    上一篇:javascript怎么去掉小数点后两位 下一篇:总结分享: 6 种JavaScript的打断点的方式(收藏学习)
    PHP编程就业班

    相关文章推荐

    • 聊聊node中怎么使用Nest.js 连接 MongoDB 数据库• 深入了解Node.js中的 Buffer(缓冲区)• 聊聊如何通过docker-compose将node服务部署到多套环境中• 如何理解 Node.js 不是完全的单线程的程序(浅析)• Node.js深入学习之浅析require函数中怎么添加钩子• 什么是Express中间件?Node中要怎么使用?• 聊聊Node.js + worker_threads如何实现多线程?(详解)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网