html合并图片两张图片合成一张图片

<!DOCTYPE html>
<html>
    <head>
    
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <meta http-equiv="Access-Control-Allow-Origin" content="*">
        <title>合并图片</title>
        <style>
            img {
                border: solid 1px #ddd;
            }
        </style>
    </head>

    <body>

        <img id="avatar" />
        <script src="http://html2canvas.hertzen.com/dist/html2canvas.min.js"></script>
        <script>
            var canvas = document.createElement("canvas");
            canvas.width = 550;
            canvas.height = 700;
            var context = canvas.getContext("2d");
            context.rect(0, 0, canvas.width, canvas.height);
            context.fillStyle = "#fff";
            context.fill();
            var img1 = new Image();
            img1.src = "img/d.jpg"; //背景图片  你自己本地的图片或者在线图片
              img1.crossOrigin = 'Anonymous';
            img1.setAttribute("crossOrigin", 'anonymous');
            var img1w = img1.width;
            var img1h = img1.height;
            var widths1 = 400 / img1w;
            var heithes1 = 300 / img1h;
            img1.onload = function() {
                if (img1w > 400 || img1h > 300) {
                    context.drawImage(img1, 50, 30, img1w * heithes1, img1h * heithes1);
                } else if (img1.width > 400) {
                    context.drawImage(img1, 50, 30, img1w * widths1, img1h * widths1);
                } else if (img1.height > 300) {
                    context.drawImage(img1, 50, 30, img1w * heithes1, img1h * heithes1);
                } else {
                    context.drawImage(img1, 50, 30, img1w, img1h);
                }
                var img2 = new Image();
                img2.src = "img/d.jpg"; //你自己本地的图片或者在线图片
                img2.crossOrigin = 'Anonymous';
                img2.setAttribute("crossOrigin", 'anonymous');
                img2.onload = function() {
                    var img2w = img2.width;
                    var img2h = img2.height;
                    var widths2 = 400 / img2w;
                    var heithes2 = 300 / img2h;;
                    if (img2w > 400 || img2h > 300) {
                        context.drawImage(img2, 50, 350, img2w * heithes2, img2h * heithes2);
                    } else if (img2.width > 400) {
                        context.drawImage(img2, 50, 350, img2w * widths2, img2h * widths2);
                    } else if (img2.height > 300) {
                        context.drawImage(img2, 50, 350, img2w * heithes2, img2h * heithes2);
                    } else {
                        context.drawImage(img2, 50, 350, img2w, img2h);
                    }
                    var base64 = canvas.toDataURL("image/png");
                    var img = document.getElementById('avatar');
                    // document.getElementById('avatar').src = base64;
                    img.setAttribute('src', base64);
                }
            }
        </script>
    </body>
</html>

Vue3本身是一个前端框架,用于构建用户界面,它并不直接提供图片处理功能。如果你想要在Vue应用中将两张图片合成一张图片,通常会使用JavaScript库如`html2canvas`、`sharp`等,配合canvas API或者服务器端的图像处理技术。 以下是一个简单的示例,假设你在客户端使用JavaScript和`html2canvas`: ```javascript import html2canvas from 'html2canvas'; async function mergeImages(image1, image2) { // 将两张图片转成canvas const canvas1 = await html2canvas(document.getElementById('image1')); const canvas2 = await html2canvas(document.getElementById('image2')); // 创建一个新的canvas,设置其宽度和高度为两者的最大值 const maxWidth = Math.max(canvas1.width, canvas2.width); const maxHeight = Math.max(canvas1.height, canvas2.height); const mergedCanvas = document.createElement('canvas'); mergedCanvas.width = maxWidth; mergedCanvas.height = maxHeight; // 获取合并后的canvas的2d渲染上下文 const ctx = mergedCanvas.getContext('2d'); // 将第一张图绘制到合并后的canvas左上角 ctx.drawImage(canvas1, 0, 0); // 将第二张图绘制到合并后的canvas的右上角 ctx.drawImage(canvas2, canvas1.width, 0); // 返回合并后的图片数据URL return mergedCanvas.toDataURL(); } // 使用示例 const image1Url = 'path/to/image1'; const image2Url = 'path/to/image2'; mergeImages(image1Url, image2Url).then(dataUrl => { console.log('合成图片的url:', dataUrl); }); ``` 注意这只是一个基本示例,实际项目中可能需要处理更多细节,例如图片加载完成、错误处理等。如果你是在服务器端操作图片,那么可能会使用像`sharp`这样的Node.js库,结合Express等后端框架来实现。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值