发布时间:2024-07-31 10:01
vue-cropper是一个可以进行图片剪辑的插件,使用于vue
github地址:https://github.com/xyxiao001/vue-cropper
npm install vue-cropper
import { VueCropper } from 'vue-cropper'
components: {
VueCropper
},
<div class="cropper" :style='{width: `${imgObj.width}px`, height: `${imgObj.height}px`}'>
<vueCropper
ref="cropper"
:img="option.img"
:outputSize="option.outputSize"
:outputType="option.outputType"
:canScale='option.canScale'
:autoCrop='option.autoCrop'
:autoCropWidth='option.autoCropWidth'
:autoCropHeight='option.autoCropHeight'
:canMoveBox='option.canMoveBox'
:canMove='option.canMove'
:centerBox='option.centerBox'
:info='option.info'
:fixedBox='option.fixedBox'
@realTime='realTime'
></vueCropper>
</div>
option: {
img: require('../assets/preview.jpg'), // 裁剪图片地址,这里可以本地图片或者链接,链接不用require
outputSize: 1, // 裁剪生成图片质量
outputType: 'jepg', // 裁剪生成图片格式
canScale: true, // 图片是否允许滚轮播放
autoCrop: true, // 是否默认生成截图框 false
info: false, // 是否展示截图框信息
autoCropWidth: 200, // 生成截图框的宽度
autoCropHeight: 200, // 生成截图框的高度
canMoveBox: true, // 截图框是否可以拖动
fixedBox: true, // 固定截图框的大小
canMove: false, // 上传图片是否可拖动
centerBox: true, // 截图框限制在图片里面
},
watch: {
'option.img': {
handler: function (val) {
const that = this
const img = new Image()
img.src = val
img.onload = function () {
that.imgObj.width = this.width
that.imgObj.height = this.height
}
},
immediate: true
}
}
<img :src='previewImg' alt="" class='previewImg'>
previewImg: null, // 预览后的图片
在组件定义@realTime事件接收预览的数据
realTime (data) {
console.log(data)
const that = this
that.previewImg = data.url
}
1 获取截图的 base64 数据:getCropData
this.$refs.cropper.getCropData(data => {
// do something
console.log(data)
})
2 获取截图的 blob 数据:getCropBlob
this.$refs.cropper.getCropBlob(data => {
// do something
console.log(data)
})
realTime (data) {
const that = this
this.$refs.cropper.getCropBlob(data => {
// 这里data数据为Blob类型,blobToDataURI方法转换成base64
this.blobToDataURI(data, function(res) {
that.previewImg = res
})
})
},
blobToDataURI(blob, callback) {
var reader = new FileReader();
reader.readAsDataURL(blob);
reader.onload = function (e) {
callback(e.target.result);
}
}
<el-button type='primary' @click='handleClick'>按钮</el-button>
<img :src="resImg" alt="" v-if="resImg" class='previewImg'>
resImg: null, //截图后图片
handleClick () {
this.$refs.cropper.getCropData(data => {
console.log(data)
this.resImg = data
this.handleDownload(data)
})
},
handleDownload (url) {
var a = document.createElement("a"); // 生成一个a元素
var event = new MouseEvent("click"); // 创建一个单击事件
a.download = "photo"; // 设置图片名称, 这里可以自定义,也可以获取图片名称进行修改
a.href = url; // 将生成的URL设置为a.href属性
a.dispatchEvent(event); // 触发a的单击事件
}
```javascript
<template>
<div class="home">
<div class="cropper" :style='{width: `${imgObj.width}px`, height: `${imgObj.height}px`}'>
<vueCropper
ref="cropper"
:img="option.img"
:outputSize="option.outputSize"
:outputType="option.outputType"
:canScale='option.canScale'
:autoCrop='option.autoCrop'
:autoCropWidth='option.autoCropWidth'
:autoCropHeight='option.autoCropHeight'
:canMoveBox='option.canMoveBox'
:canMove='option.canMove'
:centerBox='option.centerBox'
:info='option.info'
:fixedBox='option.fixedBox'
@realTime='realTime'
></vueCropper>
</div>
<img :src='previewImg' alt="" class='previewImg' ref="img">
<el-button type='primary' @click='handleClick'>按钮</el-button>
<img :src="resImg" alt="" v-if="resImg" class='previewImg'>
</div>
</template>
<script>
import { VueCropper } from 'vue-cropper'
export default {
data () {
return {
option: {
img: require('../assets/preview.jpg'), // 裁剪图片地址
outputSize: 1, // 裁剪生成图片质量
outputType: 'jepg', // 裁剪生成图片格式
canScale: true, // 图片是否允许滚轮播放
autoCrop: true, // 是否默认生成截图框 false
info: false, // 是否展示截图框信息
autoCropWidth: 200, // 生成截图框的宽度
autoCropHeight: 200, // 生成截图框的高度
canMoveBox: true, // 截图框是否可以拖动
fixedBox: true, // 固定截图框的大小
canMove: false, // 上传图片是否可拖动
centerBox: true, // 截图框限制在图片里面
},
resImg: null, //截图后图片
previewImg: null, // 预览后的图片
previewObj: {
width: 200,
height: 200
},
imgObj: {
width: 500,
height: 500
}
}
},
components: {
VueCropper
},
watch: {
'option.img': {
handler: function (val) {
const that = this
const img = new Image()
img.src = val
img.onload = function () {
that.imgObj.width = this.width
that.imgObj.height = this.height
}
},
immediate: true
}
},
methods: {
handleClick () {
this.$refs.cropper.getCropData(data => {
console.log(data)
this.resImg = data
this.handleDownload(data)
})
},
handleDownload (url) {
var a = document.createElement("a"); // 生成一个a元素
var event = new MouseEvent("click"); // 创建一个单击事件
a.download = "photo"; // 设置图片名称, 这里可以自定义,也可以获取图片名称进行修改
a.href = url; // 将生成的URL设置为a.href属性
a.dispatchEvent(event); // 触发a的单击事件
},
realTime (data) {
const that = this
this.$refs.cropper.getCropBlob(data => {
// 这里data数据为Blob类型,blobToDataURI方法转换成base64
console.log(data)
this.blobToDataURI(data, function(res) {
console.log(res)
that.previewImg = res
})
})
},
blobToDataURI(blob, callback) {
var reader = new FileReader();
reader.readAsDataURL(blob);
reader.onload = function (e) {
callback(e.target.result);
}
},
},
mounted () {
}
}
</script>
<style lang="less" scoped>
@color: #333;
.home{
width: 100%;
height: 100%;
background-color: #eee;
.cropper{
width: 500px;
height: 500px;
border: 1px solid orange;
}
.previewImg{
width: 200Px;
height: 200Px;
object-fit: cover;
border-radius: 50%;
}
}
</style>