//前提:this.pictureData是通过接口获取的照片信息 代码肯定不是cv下来就能run的,理解最重要
// 用户单张下载
userChosen(index) {
// 下载开始,调用的element组件,可以不用
let loadingInstance = Loading.service({ fullscreen: true });
//imgDown是图片地址 拼接下载图片地址
this.imgDown =this.pictureData[index].imgOrigin + this.pictureData[index].imgFileName;
//this.pictureData[index].imgFileName是图片名字
this.downloadIamge(this.imgDown, this.pictureData[index].imgFileName);
//图片下载完成,关闭elemetn组件提示下载完成
loadingInstance.close();
this.$message({
message: "下载成功",
type: "success",
});
},
// 单张下载封装的方法
downloadIamge(imgsrc, name) {
//下载图片地址和图片名
var image = new Image();
// 解决跨域 Canvas 污染问题
image.setAttribute("crossOrigin", "anonymous");
image.onload = function () {
var canvas = document.createElement("canvas");
canvas.width = image.width;
canvas.height = image.height;
var context = canvas.getContext("2d");
context.drawImage(image, 0, 0, image.width, image.height);
var url = canvas.toDataURL("image/png"); //得到图片的base64编码数据
var a = document.createElement("a"); // 生成一个a元素
var event = new MouseEvent("click"); // 创建一个单击事件
a.download = name || "photo"; // 设置图片名称
a.href = url; // 将生成的URL设置为a.href属性
a.dispatchEvent(event); // 触发a的单击事件
};
image.src = imgsrc;
}
图片单张下载
最新推荐文章于 2024-07-30 10:56:44 发布