nodejs编程实战之图片水印生成(一)
引言
图片加水印在生活中应用广泛,比如自媒体发布的图片都会带上水印,防止内容被搬运到其他平台;实名认证的身份证照片,会加上"仅作为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:tmp12.jpg").then(image => { sourceImage = image; //加载水印字体 return jimp.loadFont(jimp.FONT_SANS_64_BLACK); }).then(font => { //生成水印并保存 sourceImage.print(font, 10, 10, "lin test") .write("H:tmp12_water.jpg");//10表示水印开始的坐标,原点为左上角 })
细心的小伙伴已经发现了,在添加水印之前需要加载字体。jimp内置黑白两色从8px~128px的open sans字体,同时它也支持bitmap类型的字体文件。注意:内置字体不支持中文!
经常使用水印的小伙伴可能注意到,水印文字一般是半透明的,不会盖住原图。上面的例子不太符合要求。半透明水印可以通过半透明字体实现,也可以通过图片合成来实现。代码如下:"use strict"; //引入jimp var jimp = require("jimp"); let sourceImage; //读取原图 jimp.read("H:tmp4.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:tmp4_water.jpg"); })
通常,水印会有多行,这时需要计算图片高度和水印高度来决定行数。代码如下:"use strict"; //引入jimp var jimp = require("jimp"); let sourceImage; //读取原图 jimp.read("H:tmp6.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:tmp6_water.jpg"); })
小结
水印生成还有两个问题留在下一期介绍,1. 中文。2. 45°斜水印。敬请期待!
多校官宣!这些研究生的宿舍,没了读着书,租着房,这是一群没有宿舍的研究生。九月,有的人如愿以偿开启了令人憧憬的研究生生活,有的人却被住宿这个摆在眼前的大难题一秒拉回现实。近几年,随着研究生扩招力度不断加大,一些学
教育部加强这个学科专业建设近日,教育部网站公布对关于加强世界史学科建设,整合世界史教学资源,建设网上教学平台,试行学生跨校选课提案的答复。答复中称,下一步,教育部将进一步推动高校加强世界史相关学科专业建设,
教育部增选副高级以上教师支援西部!这些高校在列8月17日,教育部办公厅发布关于做好20212022学年高校银龄教师支援西部计划有关实施工作的通知。内容显示20212022学年,增加7所受援高校为试点高校,计划选派300330名
理工高校要增设医学类专业?官方回应近日,针对网民提出的淮北理工学院增设医学类专业和附属医院建议,安徽省教育厅给出官方回复在各项条件成熟时,将考虑是否增设医学类专业和附属医院。7月28日,网友在人民网领导留言板向安徽
重磅!放宽女性申请杰青年龄限制近日,北京市妇联联合市人才局,市科委中关村管委会,市教委,市卫健委,市国资委,市总工会,市科协等单位,联合印发科技创新巾帼行动北京行动。通过建立工作联系协调机制,共同推动四项行动,
大学教师过暑假?不存在的一转眼又到了开学季,但在大学里有一群人,压根儿就没放假。没错,他们就是大学教师。前不久,教育部辟谣取消教师寒暑假的新闻登上热搜,引发了网友关于教师寒暑假的热烈讨论。同样,大学教师也
这个市加快这些高校双一流建设日前,天津市教委发布关于印发天津市教育现代化十四五规划的通知。内容提到加快推进部市共建南开大学天津大学和天津医科大学天津工业大学天津中医药大学,着力提升国家层面双一流建设高校水平。
南极为何是禁区,极地中究竟有何秘密,让我们开启奇幻的南极之旅2020年10月俄罗斯的北海航线号搭载着地质生命气象各方面的科学家前往世界上最冷的地方,他们的目的地是深入东方科考站腹地1000多公里的东方湖!南极的探险之旅即将开启,在靠近南极的
矮大紧吹嘘犹太人,被泰国富豪榜狠狠打脸上面一半是中国人前段时间,某胖子大紧在一档网络脱口秀节目中吹嘘什么犹太人是人类的精华,跪舔味道实在是浓厚,一些不明真相的群众还真以为犹太人全世界经商无敌做生意第一。然而什么邪乎的种族,一旦遇到中华
英国认清了现实主动向中国通报女王号航母的行动信息9月10日,中英两军高层进行了视频通话,随后中国国防部发布了简短的新闻稿,通报了相关信息。对于此次通话,一位不愿意透露姓名的军事专家在接受媒体采访时表示,此次中英两军高层通话时机非
如果苏格兰独立,英国核潜艇可能转移到外国根据英国多家媒体报道,近日,英国皇家海军开始被授命开展一项可行性研究,研究在苏格兰独立的极端情况下,将位于苏格兰北部克莱德海军基地的皇家海军潜艇舰队司令部5艘机敏级攻击型核潜艇与4