美文网首页
canvas图片处理小案例

canvas图片处理小案例

作者: 剑指流云 | 来源:发表于2023-06-08 14:25 被阅读0次
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .container {
            width: 0;
            height: 0;
            overflow: hidden;
        }

        canvas {
            border: 1px solid #000;
        }
    </style>
</head>

<body>
    <form>
        <input type="file" name="img" id="btn">
    </form>
    <div class="container">
        <canvas width="0" height="0"></canvas>
    </div>
    <script>
        dataURLtoBlob = function (dataurl) {
            var arr = dataurl.split(','),
                mime = arr[0].match(/:(.*?);/)[1],
                bstr = atob(arr[1]),
                n = bstr.length,
                u8arr = new Uint8Array(n);
            while (n--) {
                u8arr[n] = bstr.charCodeAt(n);
            }
            return new Blob([u8arr], { type: mime });
        }
        //将blob转换为file
        blobToFile = function (theBlob, fileName) {
            theBlob.lastModifiedDate = new Date();
            theBlob.name = fileName;
            return theBlob;
        }

        var from = document.querySelector('#btn')
        from.onchange = function (e) {
            var imgurl = window.URL.createObjectURL(from.files[0])
            console.log(imgurl)
            var image = new Image()
            image.onload = function () {
                var myCanvas = document.querySelector('canvas')
                var ctx = myCanvas.getContext('2d')
                var imageWidth = image.width
                var imageHeight = image.height
                myCanvas.height = 750 * imageHeight / imageWidth
                myCanvas.width = 750
                ctx.drawImage(image, 0, 0, imageWidth, imageHeight, 0, 0, 750, 750 * imageHeight / imageWidth)
                var imageData = new Image();
                // canvas.toDataURL 返回的是一串Base64编码的URL
                // 指定格式 PNG  
                imageData.src = myCanvas.toDataURL("image/png");
                var bloburl = myCanvas.toDataURL();
                // 转file对象
                //调用
                var blob = dataURLtoBlob(bloburl);
                var file = blobToFile(blob, 'new');
                console.log(file)
                console.log(typeof(file))
                // 保存到本地
                // console.log('bloburl', bloburl);
                // var anchor = document.createElement('a');
                // if ('download' in anchor) {
                //     anchor.style.visibility = 'hidden';
                //     anchor.href = bloburl;
                //     anchor.download = name;

                //     document.body.appendChild(anchor);
                //     var evt = document.createEvent('MouseEvents');
                //     evt.initEvent('click', true, true);
                //     anchor.dispatchEvent(evt);

                //     document.body.removeChild(anchor);
                // } else {
                //     location.href = bloburl;
                // }
            }
            image.src = imgurl
        }

    </script>
</body>

</html>

相关文章

  • canvas图片处理

    一、图形组合方式 以下是图片组合的一些方式,有两个概念需要清楚,(目标图和源图) 目标图:先添加的图像;源图:后添...

  • 扣丁学堂HTML5教你如何用Canvas处理图片

    本篇文章扣丁学堂HTML5培训小编和大家分享一下使用Canvas处理图片的方法,文章中会有代码列出,对Canvas...

  • canvas绘制图片drawImage学习

    不得不说,html5中的canvas真的非常强大,从图片处理,到视频处理,再到游戏开发,都能见到canvas的身影...

  • Canvas与图片压缩

    之前写过一篇有关Canvas图片处理的文章,今天我们讲讲如何使用Canvas来压缩图片。 接下来我将以具体实例为大...

  • 前端如何使用canvas做图片处理

    ),可以选的方案两个: 1、前端使用canvas做图片处理; 2、服务端引用图片处理的类库来做图片处理 两个方案都...

  • Android Canvas小案例粒子爆炸效果

    概述 本文承接Android Canvas总结下述小案例仅为Canvas的api的试用总结,非项目使用demo!!...

  • Android Canvas 小案例组合动画

    概述 本文承接Android Canvas总结下述小案例仅为Canvas的api的使用总结,非项目使用demo!!...

  • 前端 利用canvas处理图片

    1.input的change事件可以拿到event.target.files 2.读取文件 let reader ...

  • 教你使用Canvas处理图片

    Canvas,中文译为“画布”,HTML5中新增了 元素,可以结合JavaScript动态地在画布中绘制图形。 今...

  • canvas实战:处理图片合集

    本文目录:本文中所有的图片都使用了下面这张 1.底片效果底片效果.png 2.灰度效果灰度效果.png 3.黑白效...

网友评论

      本文标题:canvas图片处理小案例

      本文链接:https://www.haomeiwen.com/subject/wvdxohtx.html