资讯专栏INFORMATION COLUMN

Vue使用Canvas绘制图片、矩形、线条、文字,下载图片

includecmath / 3686人阅读

摘要:前言业务场景图片储存在后台中,根据图片的地址,在页面中,查看图片,并根据坐标标注指定区域。由于浏览器的机制,使用下载图片时,并不会保存到本地,会在浏览器打开。实现原理绘制画布查看图片这里为了交互体验,使用了的弹窗方式。

1 前言 1.1 业务场景

图片储存在后台中,根据图片的地址,在vue页面中,查看图片,并根据坐标标注指定区域。

由于浏览器的机制,使用window.location.href下载图片时,并不会保存到本地,会在浏览器打开。

2 实现原理 2.1 绘制画布

    

这里为了交互体验,使用了element-ui的弹窗方式。将canvas画布放到了弹窗中。

为了突出画布效果可以在css中设置一个边框。

#mycanvas {
    border: 1px solid rgb(199, 198, 198);
}
2.2 绘制图片
//  imageUrl为后台提供图片地址
doDraw(imageUrl){
    //  获取canvas
    var canvas = document.getElementById("mycanvas")
    //  由于弹窗,确保已获取到
    var a = setInterval(() =>{
        //  重复获取
        canvas = document.getElementById("mycanvas")
        if(!canvas){
          return false
        } else {
            clearInterval(a)
            //  可以理解为一个画笔,可画路径、矩形、文字、图像
            var context = canvas.getContext("2d")
            var img = new Image()
            img.src = imageUrl
            //  加载图片
            img.onload = function(){
                if(img.complete){
                    //  根据图像重新设定了canvas的长宽
                    canvas.setAttribute("width",img.width)
                    canvas.setAttribute("height",img.height)
                    //  绘制图片
                    context.drawImage(img,0,0,img.width,img.height)
                }
            }
        }
    },1)
},

context.drawImage()方法的参数介绍,可参照 W3school

2.3 绘制矩形
context.strokeStyle = "red"
context.lineWidth = 3;
context.strokeRect(x, y, width, height)

context 同上面的定义

strokeStyle 矩形颜色

lineWidth 矩形边框宽度

x,y,width,height 矩形位置加长宽

2.4 绘制线条
context.moveTo(x1,y1) 
context.lineTo(x2,y2)
context.strokeStyle = "red"
context.lineWidth = 3;
context.stroke()

(x1,y1) (x2,y2) 线条的起点和终点坐标

strokeStyle lineWidth 线条的样式

2.5 绘制文字
context.font = "26px Arial bolder"
context.fillStyle = "red"
context.fillText(text,x,y)

font fillStyle 文字样式

text 文字内容

x,y 文字显示坐标

2.6 下载图片
// 图片地址和图片名称
downIamge (imgsrc, name) { 
    let image = new Image()
    image.setAttribute("crossOrigin", "anonymous")
    image.onload = function () {
        let canvas = document.createElement("canvas")
        canvas.width = image.width
        canvas.height = image.height
        let context = canvas.getContext("2d")
        context.drawImage(image, 0, 0, image.width, image.height)
        let url = canvas.toDataURL("image/jpg") 
        let a = document.createElement("a")
        let event = new MouseEvent("click")
        a.download = name
        a.href = url
        a.dispatchEvent(event)
    }
    image.src = imgsrc
},
3 后记

这里只是列出canvas的基础使用,具体的交互和展示还需要更多的设计。

感谢支持。若不足之处,欢迎大家指出,共勉。

如果觉得不错,记得 点赞,谢谢大家

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/103868.html

相关文章

  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制图片圆角遮罩,矩形,弧形文字

    摘要:注意事项开始时按像素大小的画布写,最后发现放在分辨率高的手机上全是锯齿,所以最后采用的宽高来写。绘制完图片头像会覆盖整个画布,所以图片得最后绘制。弧形文字需要一点一旦调整弧度。 学完我写的上一章小白上学canvas基础,我们就来这里现学现用了。这里先看我们的设计图和最终实现效果;左面是设计稿,右面是完成后的效果图: showImg(https://segmentfault.com/im...

    channg 评论0 收藏0
  • 页面动画知识点整理

    摘要:然后在节点上设置了动画属性,并将其设为前面定义的动画,每一次动画秒,表示无限循环,表示缓动方式,两个关键帧之间的变化是方式逐步变化的。 平时工作中会遇到需要实现一些存在动画的页面。这里对动画的实现知识做一个整理。页面动画的实现可以分为两类:CSS动画、Canvas动画、JavaScript动画。JavaScript动画没啥好讲的,这里就不整理了。 CSS动画 CSS3中提供了一个属性t...

    booster 评论0 收藏0
  • vue生成canvas海报图

    vue-canvas-poster vue 组件-简单属性画 Canvas 图github 概述 一个通过 css 属性画 canvas 图片的轻量级的 vue 组件(A lightweight vue components use canvas draw image by css properties.) 具有如下特性: 绘制文本(换行、超出内容省略号、中划线、下划线、文本加粗) 绘制图片(圆...

    ghnor 评论0 收藏0

发表评论

0条评论

includecmath

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<