百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

nodejs编程实战之图片水印生成(一)

qiyuwang 2024-10-31 15:50 24 浏览 0 评论

引言

图片加水印在生活中应用广泛,比如自媒体发布的图片都会带上水印,防止内容被搬运到其他平台;实名认证的身份证照片,会加上“仅作为XXX使用”的水印,防止身份证被滥用。本文从零开始介绍如何用nodejs为图片生成水印,本文的功能会发布到小编的小程序—“工具百宝箱”,欢迎拍砖。

一步一个脚印

加水印实际是对图片进行编辑,需要用到三方库—jimp,jimp全称为“JavaScript 图像编辑软件”。在package.json里面加入jimp依赖,将它引入到项目中。

{
  "name": "nodejs-console-app1",
   "main": "app.js",
  "dependencies": {
    "jimp": "0.16.1"
  }
}

jimp添加水印分为两个步骤:1. 读取需要添加水印的图片。2. 添加水印。代码如下:

'use strict';
//引入jimp
var jimp = require('jimp');
let sourceImage;
//读取原图
jimp.read("H:\\tmp\\12.jpg").then(image => {
    sourceImage = image;
    //加载水印字体
    return jimp.loadFont(jimp.FONT_SANS_64_BLACK);
}).then(font => {
    //生成水印并保存
    sourceImage.print(font, 10, 10, "lin test")
        .write("H:\\tmp\\12_water.jpg");//10表示水印开始的坐标,原点为左上角
})

细心的小伙伴已经发现了,在添加水印之前需要加载字体。jimp内置黑白两色从8px~128px的open sans字体,同时它也支持bitmap类型的字体文件。注意:内置字体不支持中文!

经常使用水印的小伙伴可能注意到,水印文字一般是半透明的,不会盖住原图。上面的例子不太符合要求。半透明水印可以通过半透明字体实现,也可以通过图片合成来实现。代码如下:

'use strict';
//引入jimp
var jimp = require('jimp');
let sourceImage;
//读取原图
jimp.read("H:\\tmp\\4.jpg").then(image => {
    sourceImage = image;
    //加载水印字体
    return jimp.loadFont(jimp.FONT_SANS_64_BLACK);
}).then(font => {
    //初始化一个透明度为0的图片
    let textImage = new jimp(sourceImage.bitmap.width, sourceImage.bitmap.height, 0x0);
    //生成水印
    textImage.print(font, 10, 10, "lin test")
        .composite(sourceImage, 0, 0, {
            mode: jimp.BLEND_MULTIPLY,
            opacitySource: 1,
            opacityDest: 0.3
        }).write("H:\\tmp\\4_water.jpg");
})

通常,水印会有多行,这时需要计算图片高度和水印高度来决定行数。代码如下:

'use strict';
//引入jimp
var jimp = require('jimp');

let sourceImage;
//读取原图
jimp.read("H:\\tmp\\6.jpg").then(image => {
    sourceImage = image;
    //加载水印字体
    return jimp.loadFont(jimp.FONT_SANS_64_BLACK);
}).then(font => {
    //初始化一个透明度为0的图片
    let textImage = new jimp(sourceImage.bitmap.width, sourceImage.bitmap.height, 0x0);
    //计算水印高度
    let textHeight = jimp.measureTextHeight(font, "lin test");
    //计算行数,注意水印高度从10开始
    let rowNum = Math.floor((sourceImage.bitmap.height - 10) / textHeight)

    for (let i = 0; i < rowNum; ++i) {
        textImage.print(font, 10, 10 + i * textHeight, "lin test");
    }

    //生成水印
    textImage.composite(sourceImage, 0, 0, {
        mode: jimp.BLEND_MULTIPLY,
        opacitySource: 1,
        opacityDest: 0.3
    }).write("H:\\tmp\\6_water.jpg");
})

小结

水印生成还有两个问题留在下一期介绍,1. 中文。2. 45°斜水印。敬请期待!

相关推荐

windows开启telnet服务,检测远程服务端口是否可以连通

本文介绍windwos开启telnet服务,telnet服务一般可以用于检测远程主机的某个端口服务是否可以连通,在日常的工作中,我们经常会遇到在本地的windows检测远程服务端口是否可以连通。win...

仅在Web登录新华三交换机条件下启用设备Telnet登录方式

概述Web登录新华三交换机可以在“网络-服务”页面中启用设备Telnet服务或SSH服务,也可以在“设备-管理员”设置管理员用户的可用服务,然而,在设备Web页面中,无法设置lineVTY用户线【l...

思科交换机,路由器如何关闭telnet 开启ssh服务

SSH为建立在应用层基础上的安全协议。SSH是目前较可靠,专为远程登录会话和其他网络服务提供安全性的协议。利用SSH协议可以有效防止远程管理过程中的信息泄露问题。今天我们就来说说思科交换机,路...

智能化弱电行业常用的DOS命令,掌握了你也能成为...

前言在做智能化弱电项目时,前端摄像头设备安装结束后,我们会对网络摄像头进行调试,调试过程中会遇到前端摄像头没有图像或者图像出来了画面卡顿的现象。我们会采用ping命令来测试网络的连通性和网络承载能力。...

「干货」eNSP模拟器之配置Telnet登录

配置说明:配置Telnet,使R2(模拟PC)通过SW1登录到R1进行管理和配置。操作步骤:system-view##进入系统视图[Huawei]sysnameR1##改名为R1[R1]int...

win11开启telnet服务怎么操作 win11打开telent指令是什么

telnet服务是我们在进行远程连接的时候,必须要打开的一项功能。但是有不少用户们不清楚在windows11系统中怎么开启telnet服务。今天小编就使用详细的图文教程,来给大家说明一下打开telen...

华三(H3C)交换机Telnet的远程登陆

一,配置交换机管理IP[SW1]vlan20//创建管理vlan[SW1]interfacevlan20//进入vlan接口[SW1-Vlanif20]ipaddress192.168....

win10 telnet命令怎么查看端口是否打开

可能大家也会遇到这个问题,win10telnet命令查看端口是否打开的步骤是什么?具体方法如下:1、键盘输入快捷键WIN+R,打开运行窗口。2、输入cmd,点击确定按钮。3、弹出cmd命令行窗...

Windows 7如何打开Telnet功能(win7系统打开telnet)

Windows7默认安装后是没有开启telnet客户端功能的,例如,我们在开始菜单中输入cmd,然后使用telnet命令,会弹出下图提示:‘telnet’不是内部或外部命令,也不是可运行程序或批处理文...

为锐捷路由器交换机开启web和telnet,实现轻松管理

笔者上一篇文章写了关于锐捷二层交换机配置教程,那么接下来讲一下锐捷的路由交换设备配置web、telnet技巧。同样,今天的教程也是基于命令行,比较简单,适合新手小白进行学习。准备工作配置前准备:con...

一文学会telnet命令的用途和使用方法

Telnet是一个古老的远程登录协议,可以让本地计算机获得远程计算机的工作能力。它采用了TCP的可靠连接方式,可以连接任何网络互通的远程计算机。不过由于它采用了明文传输方式,存在安全风险,目前已经很少...

Telnet命令是什么?如何使用?(telnet命令在哪里开启)

telnet命令是一个常用的远程登陆工具,使用它,我们可以快捷地登陆远程服务器进行操作。那么如何使用telnet命令呢?首先,我们需要打开telnet功能,任何电脑默认是关闭此功能的,开启方式如下:打...

win11系统如何开启telnet服务(拷贝版本)

  我们要知道,Telnet协议是Internet远程登陆服务的标准协议,可以使用户在本地计算机上完成远程主机的工作,不过对于一些刚接触win11中文版系统的用户来说,可能还不知道telnet服务在哪...

如何开启telnet客户端(如何开启telnet服务)

Telnet协议是TCP/IP协议家族中的一员,是Internet远程登陆服务的标准协议和主要方式,Telnet是常用的远程控制Web服务器的方法。工作中经常用到telnet客户端,但在windows...

Telnet 是什么,如何启用它?(telnet有什么用)

对于Internet等TCP/IP网络,Telnet是一个终端仿真程序。Telnet软件在您的系统上运行并将您的个人计算机链接到网络服务器。它将所有数据转换为纯文本这一事实被认为是易受...

取消回复欢迎 发表评论: