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

前端js用canvas合成图片并转file对象

强大的前端js可以做很多东西,今天用canvas合成图片并添加文字,然后转成file对象进行上传。代码如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
</head>
<body>
	<canvas id="myCanvas"></canvas>
</body>
<script>
	window.onload = function() {
		// 获取Canvas元素
		var canvas = document.getElementById('myCanvas');
		var ctx = canvas.getContext('2d');
		 
		// 创建新的Image对象
		var bgimg = new Image();
		bgimg .crossOrigin = "Anonymous";  // 加这句
		// 设置图片源地址
		bgimg.src = 'https://q5.itc.cn/q_70/images03/20240406/2c8f1d2cd13e4d4392fa07ccaab1f219.jpeg';
		 
		// 当图片加载完成后,将其绘制到Canvas上
		bgimg.onload = function() {
			// 设置Canvas的宽高,如果不设置,默认以图片的尺寸显示
			canvas.width = bgimg.width;
			canvas.height = bgimg.height;
		 
			// 将图片绘制到Canvas上
			ctx.drawImage(bgimg, 0, 0);
			
			// 合并图片
			var img1 = new Image();
			img1.src = 'https://q5.itc.cn/q_70/images03/20240406/2c8f1d2cd13e4d4392fa07ccaab1f219.jpeg';
			img1.onload = function() {
				// 将图片绘制到bgimg上
				// 横图  等比例缩小 上下居中绘制
				var width = bgimg.width / 2;
				var height = (width * img1.height) / img1.width;
				ctx.drawImage(img1, 0, (bgimg.height / 2) - (height / 2),width,height);
				// 如果文字被图片遮住是因为异步,可以把绘制文字放在这里面进行绘制...
			}
			// 添加文字
			ctx.font = '50px Arial';
			ctx.fillStyle = '#000';
			var txt = "那是一个阳光明媚的上午十点,我和\n越添科技的伙伴们一同来到了\n深圳的心智青老年大学,开展一\n场特别的梦想。";
			var txtX = (bgimg.width / 2) + 300;
			text(ctx,txt,txtX,600,(bgimg.width - txtX - 300),100);
			
			// 创建Blob对象
			canvas.toBlob(blob => {
				const file = new File([blob], "canvas.png", {type: "image/png"});
				// file对象可在这里进行上传
				console.log(11111,file);
			});
		};
		
		/** 绘制自动换行文字
		 * @param ctx 画布上下文
		 * @param text 文字
		 * @param x 坐标x
		 * @param y 坐标y
		 * @param maxWidth 文字最大宽度(0表示竖排显示)
		 * @param maxWidth 文字行高
		 * @param split 按照指定符号切割成段落
		 */
		function text(ctx,text,x=0,y=0,maxWidth=300,lineHeight=20,split="\n"){
			ctx.save();
			// 将文本分割成多个段落
			var paragraph = text.split(split);
			for(var k = 0; k < paragraph.length; k++) {
				if(k != 0){
					y += lineHeight;
				}
				var lines = paragraph[k].split('');
				var line = "";
				for(var i = 0; i < lines.length; i++) {
					line += lines[i];
					if(ctx.measureText(line).width > maxWidth){
						line = lines[i];
						y += lineHeight;
					}
					ctx.fillText(line, x, y);
				}
			}
			ctx.restore();
		}
	}
</script>
</html>

到此完成,跑一下看看是不是可以了。


http://www.kler.cn/a/392549.html

相关文章:

  • ESP32 I2S音频总线学习笔记(一):初识I2S通信与配置基础
  • 【AUTOSAR 基础软件】Can模块详解(Can栈之驱动模块)
  • 动态规划<八> 完全背包问题及其余背包问题
  • kubelet状态错误报错
  • 直观解读 JuiceFS 的数据和元数据设计(一)
  • ASP.NET CORE 依赖注入的三种方式,分别是什么,使用场景
  • WebRTC视频 03 - 视频采集类 VideoCaptureDS 上篇
  • openresty入门教程:rewrite_by_lua_block
  • Linux应用——线程池
  • Spring Boot框架:电商解决方案的构建
  • 2.操作系统常见面试问题2
  • MySQL数据库常用命令大全(完整版——表格形式)
  • 「漏洞复现」某赛通电子文档安全管理系统 HookService SQL注入漏洞复现(CVE-2024-10660)
  • C++(Qt)软件调试---符号转换工具cv2pdb (24)
  • 【c++丨STL】list的使用
  • 【目标检测】【Ultralytics-YOLO系列】Windows11下YOLOV5人脸目标检测
  • 【ACM出版】第四届信号处理与通信技术国际学术会议(SPCT 2024)
  • 软间隔支持向量机
  • 表格理解专题(五)表头和数据项定义
  • spark 设置hive.exec.max.dynamic.partition不生效
  • 01-Ajax入门与axios使用、URL知识
  • 深入理解指针
  • 搜索引擎算法解析提升搜索效率的关键要素
  • 【Linux】Ubuntu中muduo库的编译环境安装
  • C# (定时器、线程)
  • Flutter【04】高性能表单架构设计