通过HTML Canvas 在图片上绘制文字

目录

前言

[一、HTML Canvas 简介](#一、HTML Canvas 简介)

二、准备工作

三、绘制图片

四、绘制文字

五、完整代码

效果演示:


前言

HTML canvas 为我们提供了无限的创意可能性。今天,我们就来探索一下如何通过 HTML canvas 将图片和文字绘制到图片上,创造出独特而富有个性的视觉效果。

一、HTML Canvas 简介

HTML canvas 是一个可以使用 JavaScript 在网页上绘制图形的元素。它提供了一组强大的绘图 API,可以让我们绘制各种形状、图像和文本。通过 canvas,我们可以实现动态的图形效果,为网页增添生动和交互性。

二、准备工作

首先需要在 HTML 页面中创建一个 canvas 元素。可以使用以下代码:

html 复制代码
var canvas = document.createElement("canvas");
					canvas.width = image.width;
					canvas.height = image.height;

然后,在 JavaScript 中获取 canvas 元素和绘图上下文:

html 复制代码
// 获取上下文对象
					var ctx = canvas.getContext("2d");

三、绘制图片

1.加载图片

首先,我们需要加载要绘制到 canvas 上的图片。可以使用 Image 对象来加载图片,并在图片加载完成后进行绘制。

html 复制代码
<img id="resultImage" src="12images/wz.png" alt="结果图片" title="123">

image.onload = function() {

}

2.绘制图片到 canvas

当图片加载完成后,我们可以使用 drawImage 方法将图片绘制到 canvas 上。

html 复制代码
// 将图片绘制到画布上
					ctx.drawImage(image, 0, 0);

四、绘制文字

1.设置文字样式

在绘制文字之前,我们可以设置文字的样式,包括字体、字号、颜色等。

html 复制代码
// 设置文本样式
					ctx.font = "24px Arial";
					ctx.fillStyle = "black";

2.绘制文字到 canvas

使用 fillText 方法可以将文字绘制到 canvas 上。

html 复制代码
// 将文本绘制到画布上
					ctx.fillText(inputText, 40, 50); // 指定文本的位置

五、完整代码

html 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
	</head>
	<body>
		<input type="text" id="textInput">
		<button onclick="addTextToImage()">将文本添加到图片</button>
		<img id="resultImage" src="12images/wz.png" alt="结果图片" title="123">

		<div id="wz">

		</div>

		<script type="text/javascript">
			function addTextToImage() {
				var inputText = document.getElementById("textInput").value; // 获取输入框的值
				console.log(inputText);
				// 创建一个新的图片对象
				var image = new Image();
				image.src = "images/weizhi.png"; // 图片的路径
				// 当图片加载完成后执行操作
				image.onload = function() {
					var canvas = document.createElement("canvas");
					canvas.width = image.width;
					canvas.height = image.height;
					// 获取上下文对象
					var ctx = canvas.getContext("2d");

					// 将图片绘制到画布上
					ctx.drawImage(image, 0, 0);

					// 设置文本样式
					ctx.font = "24px Arial";
					ctx.fillStyle = "black";

					// 将文本绘制到画布上
					ctx.fillText(inputText, 40, 50); // 指定文本的位置

					// 将画布中的内容存储为图片
					var resultImage = document.getElementById("resultImage");
					resultImage.src = canvas.toDataURL("image/jpeg");
				};
			}
		</script>
	</body>
</html>

效果演示:

相关推荐
moxiaoran5753几秒前
Spring Cloud Gateway 动态路由实现方案
运维·服务器·前端
市民中心的蟋蟀几秒前
第十一章 这三个全局状态管理库之间的共性与差异 【上】
前端·javascript·react.js
vvilkim14 分钟前
Flutter 常用组件详解:Text、Button、Image、ListView 和 GridView
前端·flutter
vvilkim21 分钟前
Flutter 命名路由与参数传递完全指南
前端·flutter
NA22 分钟前
redis
前端
你真好看_22 分钟前
6年低代码 零代码 系统二开人员的角度,看低代码 到底有多好用!!!
前端
JC_You_Know29 分钟前
边缘计算一:现代前端架构演进图谱 —— 从 SPA 到边缘渲染
前端·人工智能·边缘计算
DoraBigHead32 分钟前
深入 JavaScript 作用域机制:透视 V8 引擎背后的执行秘密
前端·javascript
Tu_Jipang33 分钟前
前端从零搭建企业级后台系统实战指南
前端
快起来别睡了34 分钟前
CSS定位的奥秘:从文档流到position,一文讲透前端布局核心!
前端·css·程序员