当前位置: 首页 > news >正文

JavaScript实现的复杂功能:自动生成带水印的图片

 #程序员的崩溃瞬间

在本文中,我们将讨论一个JavaScript实现的复杂功能,该功能可以自动为图片添加水印。这个功能在许多场景中都非常有用,例如,如果你想保护你的图片版权,或者你想在你的网站上显示自定义的水印。

一、功能概述

这个功能的核心是使用HTML5的Canvas API和JavaScript的图像处理能力。它首先加载一张图片,然后在图片上绘制一个水印。水印可以是任何你想要的文本或图像,并且可以调整大小、位置和颜色。此外,这个功能还包括了图片裁剪和水印透明度调整等高级功能。

二、实现细节 

  1. 加载图片:首先,我们需要加载一张图片。这可以通过HTML的<img>标签或者JavaScript的Image对象来完成。在这个例子中,我们将使用Image对象。

  2. 在实际操作中,我们可以使用JavaScript的Image对象来加载图片。这是一个非常实用的方式,因为你可以控制图片加载完成后的操作。以下是一个简单的示例:

  3. var img = new Image(); // 创建一个新的Image对象  
    img.src = 'image.jpg'; // 设置图片的源地址  
    img.onload = function() {  // 当图片加载完成后,这个函数将被调用  // 在这里,你可以进行图片处理,例如裁剪、添加水印等  
    };

    在这个示例中,我们创建了一个新的Image对象,并设置了它的源地址。然后,我们定义了一个onload函数,当图片加载完成后,这个函数将被调用。在这个函数中,你可以进行你需要的图片处理。

例如,如果你想裁剪图片的中心区域,你可以这样做:

  1. 创建Canvas:然后,我们需要创建一个Canvas元素,这是我们将要在其上绘制水印的地方。

    创建一个Canvas元素是使用HTML5 Canvas API的必要步骤。以下是一个简单的示例:

    <canvas id="myCanvas" width="500" height="500"></canvas>

    在这个例子中,我们创建了一个id为"myCanvas"的canvas元素,并设置了其宽度和高度。

    在JavaScript中,你可以通过document.getElementById方法来获取这个canvas元素:

    var canvas = document.getElementById('myCanvas');

    然后,你可以使用getContext方法来获取2D渲染上下文:

    var ctx = canvas.getContext('2d');

    裁剪图片:在添加水印之前,我们可以使用Canvas的drawImage方法将图片裁剪到所需的大小。通过调整drawImage方法的参数,我们可以选择裁剪区域的位置和大小。

    使用Canvas的drawImage方法可以裁剪图片。drawImage方法有9个参数:

  2. 第一个参数是原始图片。

  3. 第二个参数是图片在Canvas上的x坐标。

  4. 第三个参数是图片在Canvas上的y坐标。

  5. 第四个参数是图片的宽度。

  6. 第五个参数是图片的高度。

  7. 第六个参数是裁剪区域的x坐标。

  8. 第七个参数是裁剪区域的y坐标。

  9. 第八个参数是裁剪区域的宽度。

  10. 第九个参数是裁剪区域的高度。

    ctx.drawImage(image, (image.width - cropWidth) / 2, (image.height - cropHeight) / 2, cropWidth, cropHeight, 0, 0, cropWidth, cropHeight);

    其中,cropWidthcropHeight是你想要的裁剪区域的尺寸。

  1. 绘制水印:接下来,我们将使用Canvas的drawImage方法将水印绘制到图片上。我们可以调整水印的大小、位置和颜色。另外,我们还可以通过设置水印的透明度来控制水印的可见程度。

 绘制水印是一个相对直接的过程。你需要定义你想要的水印文本、颜色、位置和大小。以下是一个简单的示例: 

ctx.font = '30px Arial'; // 设置字体大小和类型  
ctx.fillStyle = 'red'; // 设置填充颜色  
ctx.fillText('Watermark', 50, 50); // 绘制水印文本

在这个例子中,我们设置了字体大小和类型,并设置了填充颜色。然后,我们使用fillText方法来绘制水印文本。你可以调整水印的位置和大小,以及颜色。

透明度可以通过设置globalAlpha属性来控制:

ctx.globalAlpha = 0.5; // 设置透明度为0.5

然后,绘制水印:

ctx.fillText('Watermark', 50, 50); // 绘制水印文本

最后,不要忘记将globalAlpha重置为1,以恢复正常的绘制模式:

ctx.globalAlpha = 1; // 重置透明度为1

这样,你就可以在你的图片上添加一个带透明度的水印了。

  1. 导出图片:最后,我们可以将Canvas的内容导出为一张新的图片。这可以通过将Canvas的toDataURL方法的结果设置为<img>标签的src属性来完成。

 要将Canvas的内容导出为图片,你可以使用Canvas的toDataURL方法。这个方法返回一个包含图片数据的URL,你可以将这个URL设置为<img>标签的src属性,从而在网页上显示这个图片。以下是一个简单的示例:

var dataURL = canvas.toDataURL('image/png'); // 将Canvas内容导出为PNG格式的图片  
var img = document.getElementById('outputImage'); // 获取<img>标签  
img.src = dataURL; // 将<img>标签的src属性设置为dataURL

在这个例子中,我们首先使用toDataURL方法将Canvas的内容导出为一个PNG格式的图片的URL。然后,我们获取ID为outputImage<img>标签,并将它的src属性设置为这个URL。这样,你就可以在网页上看到Canvas的内容了。

三、代码示例

下面是一个完整的示例代码,展示了如何实现带水印的图片生成功能,包括图片裁剪和水印透明度调整等高级功能:

<!DOCTYPE html>  
<html lang="en">  
<head>  <meta charset="UTF-8">  <meta name="viewport" content="width=device-width, initial-scale=1.0">  <title>自动添加水印</title>  
</head>  
<body>  <input type="file" id="imageInput" accept="image/*">  <canvas id="canvas"></canvas>  <img id="outputImage" style="display: none;">  <script>  const canvas = document.getElementById('canvas');  const ctx = canvas.getContext('2d');  const imageInput = document.getElementById('imageInput');  const outputImage = document.getElementById('outputImage');  let image;  imageInput.addEventListener('change', function(e) {  image = new Image();  image.onload = function() {  // 裁剪图片  const cropWidth = 500; // 裁剪宽度  const cropHeight = 300; // 裁剪高度  const cropX = (image.width - cropWidth) / 2; // 裁剪起始位置的x坐标  const cropY = (image.height - cropHeight) / 2; // 裁剪起始位置的y坐标  canvas.width = cropWidth; // 设置画布宽度为裁剪宽度  canvas.height = cropHeight; // 设置画布高度为裁剪高度  ctx.drawImage(image, cropX, cropY, cropWidth, cropHeight, 0, 0, cropWidth, cropHeight); // 在画布上绘制裁剪后的图片  // 添加水印并调整透明度  addWatermark(ctx, 'Watermark', 'watermarkColor', 50, 50, 0.5); // 调整透明度为0.5  // 导出图片  outputImage.src = canvas.toDataURL();  };  image.src = URL.createObjectURL(e.target.files[0]);  });  function addWatermark(context, text, color, x, y, opacity) {  context.font = '30px Arial'; // 设置字体大小和类型  context.fillStyle = color; // 设置填充颜色  context.globalAlpha = opacity; // 设置透明度  context.fillText(text, x, y); // 绘制水印文本  context.globalAlpha = 1; // 重置透明度为默认值1  }  </script>  
</body>  
</html>

相关文章:

JavaScript实现的复杂功能:自动生成带水印的图片

#程序员的崩溃瞬间 在本文中&#xff0c;我们将讨论一个JavaScript实现的复杂功能&#xff0c;该功能可以自动为图片添加水印。这个功能在许多场景中都非常有用&#xff0c;例如&#xff0c;如果你想保护你的图片版权&#xff0c;或者你想在你的网站上显示自定义的水印。 一、…...

图神经网络|8.2 图卷积的计算基本方法

不同于一般的神经网络&#xff0c;网络层数的并不用特别多。 原因是只需要少数次数迭代后&#xff08;当迭代次数为图上的直径&#xff1f;任意两点最短距离的最大值&#xff1f;&#xff09;&#xff0c;某节点便可获取得到图上所有的节点。 通俗的理解是&#xff0c;在社会中…...

equals()与hashCode()方法详解

java.lang.Object类中有两个非常重要的方法&#xff1a; 1 2 public boolean equals(Object obj) public int hashCode() Object类是类继承结构的基础&#xff0c;所以是每一个类的父类。所有的对象&#xff0c;包括数组&#xff0c;都实现了在Object类中定义的方法。 回到…...

六、基于Flask、Flasgger、marshmallow的开发调试

基于Flask、Flasgger、marshmallow的开发调试 问题描述调试方法一调试方法二调试方法三 问题描述 现在有一个传入传出为json格式文件的&#xff0c;Flask-restful开发的程序&#xff0c;需要解决如何调试的问题。 #!/usr/bin/python3 # -*- coding: utf-8 -*- # Project :…...

TypeScript 从入门到进阶之基础篇(三) 元组类型篇

系列文章目录 TypeScript 从入门到进阶系列 TypeScript 从入门到进阶之基础篇(一) ts基础类型篇TypeScript 从入门到进阶之基础篇(二) ts进阶类型篇TypeScript 从入门到进阶之基础篇(三) 元组类型篇TypeScript 从入门到进阶之基础篇(四) symbol类型篇 持续更新中… 文章目录 …...

现代CPU的多种运行模式

目前的CPU大多是支持X86-64技术的兼容CPU&#xff0c;这包括AMD64以及Intel的IA32E&#xff08;后被正式命名为EM64T&#xff0c;Extended Memory 64 Technology&#xff09;&#xff0c;因为AMD64先出&#xff0c;而EM64T与AMD64完全兼容&#xff0c;所以也统一称为AMD64技术。…...

Python PDF处理模块pypdf库详解

概要 PDF&#xff08;Portable Document Format&#xff09;是一种常见的文档格式&#xff0c;广泛用于存储和共享文本和图像数据。在 Python 中&#xff0c;有许多库可以用于处理 PDF 文件&#xff0c;其中之一就是 PyPDF。PyPDF 是一个功能强大的库&#xff0c;它允许你读取…...

C++上位软件通过LibModbus开源库和西门子S7-1200/S7-1500/S7-200 PLC进行ModbusTcp 和ModbusRTU 通信

前言 一直以来上位软件比如C等和西门子等其他品牌PLC之间的数据交换都是大家比较头疼的问题&#xff0c;尤其是C上位软件程序员。传统的方法一般有OPC、Socket 等&#xff0c;直到LibModbus 开源库出现后这种途径对程序袁来说又有了新的选择。 Modbus简介 Modbus特点 1 &#…...

PLSQL Developer 15安装和oracle客户端安装

文章目录 前言一、PLSQL Developer1.下载2.安装 二、oracle客户端1.下载2.环境变量 三、使用1. oci2. 连接3. 配置文件 总结 前言 oracle是经常使用的数据库&#xff0c;PLSQL Developer是众多产品中比较不错的一款工具&#xff0c;接下来我们来介绍PLSQL Developer的安装和使…...

【深度deepin】深度安装,jdk,tomcat,Nginx安装

目录 一 深度 1.1 介绍 1.2 与别的操作系统的优点 二 下载镜像文件及VM安装deepin 三 jdk&#xff0c;tomcat&#xff0c;Nginx安装 3.1 JDK安装 3.2 安装tomcat 3.3 安装nginx 一 深度 1.1 介绍 由深度科技社区开发的开源操作系统&#xff0c;基于Linux内核&#xf…...

解决flask启动报错:ImportError: DLL load failed while importing _dukpy: 找不到指定的程序

现象&#xff1a; 原因&#xff1a;dukpy没有win32执行库 解决办法&#xff1a; 到lfd.uci.edu 第三方库下载dukpy的win32 whl文件 注意&#xff1a; 需要跟你python版本和windows平台&#xff08;32位/64位&#xff09;对应 https://www.lfd.uci.edu/~gohlke/pythonlibs/#…...

腾讯面试总结

腾讯 一面 mysql索引结构&#xff1f;redis持久化策略&#xff1f;zookeeper节点类型说一下&#xff1b;zookeeper选举机制&#xff1f;zookeeper主节点故障&#xff0c;如何重新选举&#xff1f;syn机制&#xff1f;线程池的核心参数&#xff1b;threadlocal的实现&#xff…...

面向对象进阶(static关键字,继承,方法重写,super,this)

文章目录 面向对象进阶部分学习方法&#xff1a;今日内容教学目标 第一章 复习回顾1.1 如何定义类1.2 如何通过类创建对象1.3 封装1.3.1 封装的步骤1.3.2 封装的步骤实现 1.4 构造方法1.4.1 构造方法的作用1.4.2 构造方法的格式1.4.3 构造方法的应用 1.5 this关键字的作用1.5.1…...

Blazor项目如何调用js文件

以下是来自千问的回答并加以整理&#xff1a;&#xff08;说一句&#xff0c;文心3.5所给的回答不完善&#xff0c;根本运行不起来&#xff0c;4.0等有钱了试试&#xff09; 在Blazor项目中引用JavaScript文件&#xff08;.js&#xff09;以实现与JavaScript的互操作&#xff…...

Windows11 - Ubuntu 双系统及 ROS、ROS2 安装

系列文章目录 前言 一、Windows11 - Ubuntu 双系统安装 硬件信息&#xff1a; 设备名称 DESKTOP-B62D6KE 处理器 13th Gen Intel(R) Core(TM) i5-13500H 2.60 GHz 机带 RAM 40.0 GB (39.8 GB 可用) 设备 ID 7673EF86-8370-41D0-8831-84926668C05A 产品 ID 00331-10000-0000…...

深度学习(学习记录)

题型&#xff1a;填空题判断题30分、简答题20分、计算题20分、综合题&#xff08;30分&#xff09; 综合题&#xff08;解决实际工程问题&#xff0c;不考实验、不考代码、考思想&#xff09; 一、深度学习绪论&#xff08;非重点不做考察&#xff09; 1、传统机器学习&…...

html5实现好看的个人博客模板源码

文章目录 1.设计来源1.1 主界面1.2 认识我界面1.3 我的文章界面1.4 我的模板界面1.5 文章内容界面 2.结构和源码2.1 目录结构2.2 源代码 源码下载 作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_43151418/article/details/135368653 html5实现好看…...

SpringSecurity深度学习

SpringSecurity简介 spring Security是什么&#xff1f; Spring Security 是一个强大且高度可定制的身份验证和访问控制框架&#xff0c;用于保护基于Spring的应用程序。它是Spring项目的一部分&#xff0c;旨在为企业级系统提供全面的安全性解决方案。 一个简单的授权和校验…...

odoo17 | 用户界面的基本交互

前言 现在我们已经创建了我们的新模型及其 相应的访问权限&#xff0c;是时候了 与用户界面交互。 在本章结束时&#xff0c;我们将创建几个菜单以访问默认列表 和窗体视图。 数据文件 &#xff08;XML&#xff09; Odoo在很大程度上是数据驱动的&#xff0c;因此模块定义的…...

Intel 性能监视器之二

全文来自Intel开发者手册&#xff1a;Intel? 64 and IA-32 Architectures Software Developer’s Manual Volume 3B System Programming Guide.pdf 注意&#xff1a;下文中已经指出手册中的对应页面和章节&#xff0c;请对照手册原文看&#xff0c;任何个人理解错误&#xff…...

业务系统对接大模型的基础方案:架构设计与关键步骤

业务系统对接大模型&#xff1a;架构设计与关键步骤 在当今数字化转型的浪潮中&#xff0c;大语言模型&#xff08;LLM&#xff09;已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中&#xff0c;不仅可以优化用户体验&#xff0c;还能为业务决策提供…...

SCAU期末笔记 - 数据分析与数据挖掘题库解析

这门怎么题库答案不全啊日 来简单学一下子来 一、选择题&#xff08;可多选&#xff09; 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘&#xff1a;专注于发现数据中…...

鸿蒙中用HarmonyOS SDK应用服务 HarmonyOS5开发一个医院挂号小程序

一、开发准备 ​​环境搭建​​&#xff1a; 安装DevEco Studio 3.0或更高版本配置HarmonyOS SDK申请开发者账号 ​​项目创建​​&#xff1a; File > New > Create Project > Application (选择"Empty Ability") 二、核心功能实现 1. 医院科室展示 /…...

服务器硬防的应用场景都有哪些?

服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式&#xff0c;避免服务器受到各种恶意攻击和网络威胁&#xff0c;那么&#xff0c;服务器硬防通常都会应用在哪些场景当中呢&#xff1f; 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...

江苏艾立泰跨国资源接力:废料变黄金的绿色供应链革命

在华东塑料包装行业面临限塑令深度调整的背景下&#xff0c;江苏艾立泰以一场跨国资源接力的创新实践&#xff0c;重新定义了绿色供应链的边界。 跨国回收网络&#xff1a;废料变黄金的全球棋局 艾立泰在欧洲、东南亚建立再生塑料回收点&#xff0c;将海外废弃包装箱通过标准…...

解决本地部署 SmolVLM2 大语言模型运行 flash-attn 报错

出现的问题 安装 flash-attn 会一直卡在 build 那一步或者运行报错 解决办法 是因为你安装的 flash-attn 版本没有对应上&#xff0c;所以报错&#xff0c;到 https://github.com/Dao-AILab/flash-attention/releases 下载对应版本&#xff0c;cu、torch、cp 的版本一定要对…...

实现弹窗随键盘上移居中

实现弹窗随键盘上移的核心思路 在Android中&#xff0c;可以通过监听键盘的显示和隐藏事件&#xff0c;动态调整弹窗的位置。关键点在于获取键盘高度&#xff0c;并计算剩余屏幕空间以重新定位弹窗。 // 在Activity或Fragment中设置键盘监听 val rootView findViewById<V…...

云原生玩法三问:构建自定义开发环境

云原生玩法三问&#xff1a;构建自定义开发环境 引言 临时运维一个古董项目&#xff0c;无文档&#xff0c;无环境&#xff0c;无交接人&#xff0c;俗称三无。 运行设备的环境老&#xff0c;本地环境版本高&#xff0c;ssh不过去。正好最近对 腾讯出品的云原生 cnb 感兴趣&…...

水泥厂自动化升级利器:Devicenet转Modbus rtu协议转换网关

在水泥厂的生产流程中&#xff0c;工业自动化网关起着至关重要的作用&#xff0c;尤其是JH-DVN-RTU疆鸿智能Devicenet转Modbus rtu协议转换网关&#xff0c;为水泥厂实现高效生产与精准控制提供了有力支持。 水泥厂设备众多&#xff0c;其中不少设备采用Devicenet协议。Devicen…...

算法刷题-回溯

今天给大家分享的还是一道关于dfs回溯的问题&#xff0c;对于这类问题大家还是要多刷和总结&#xff0c;总体难度还是偏大。 对于回溯问题有几个关键点&#xff1a; 1.首先对于这类回溯可以节点可以随机选择的问题&#xff0c;要做mian函数中循环调用dfs&#xff08;i&#x…...