vue 图片写入文字,图片注入文字,图片添加文字

添加的文字是写入图片的,文字会随着图片的大小、位置改变而改变

完成的效果:
在这里插入图片描述
在这里插入图片描述

代码:

<template>
    <div>
        <div>写入前</div>
        <img src="https://img0.baidu.com/it/u=1384155777,1106731832&fm=253&fmt=auto&app=138&f=JPEG?w=600&h=400" />
        <div>写入后</div>
        <img :src="currentImg">
    </div>
</template>
<script>
export default {
    data() {
        return {
            currentImg: ""
        }
    },
    mounted() {
        this.addTextEvent()
    },
    methods: {
        addTextEvent() {
            var _this = this
            let canvas = document.createElement("canvas");
            canvas.width = 600;
            canvas.height = 400;
            let myImage = new Image();
            myImage.src = "https://img0.baidu.com/it/u=1384155777,1106731832&fm=253&fmt=auto&app=138&f=JPEG?w=600&h=400";  // 需要添加文字的图片
            myImage.crossOrigin = "Anonymous";
            let context = canvas.getContext("2d");
            myImage.onload = function () {
                context.drawImage(myImage, 0, 0, canvas.width, canvas.height);
                context.font = "20px Courier New";
                context.fillStyle = 'red'
                // context.textAlign = 'end' //文字右对齐
                context.fillText("我是写入的文字", 250, 350);  // 文字的内容和位置
                let base64 = canvas.toDataURL("image/png"); // "image/png" 这里注意一下
                _this.currentImg = base64
            }
        }
    },
}
</script>
  • 2
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值