85 lines
2.0 KiB
Vue
85 lines
2.0 KiB
Vue
|
<!--
|
|||
|
* @Descripttion: 图像裁剪组件
|
|||
|
* @version: 1.0
|
|||
|
* @Author: sakuya
|
|||
|
* @Date: 2021年7月24日17:05:43
|
|||
|
* @LastEditors:
|
|||
|
* @LastEditTime:
|
|||
|
* @other: 代码完全开源,欢迎参考,也欢迎PR
|
|||
|
-->
|
|||
|
|
|||
|
<template>
|
|||
|
<div class="sc-cropper">
|
|||
|
<div class="sc-cropper__img">
|
|||
|
<img :src="src" ref="img">
|
|||
|
</div>
|
|||
|
<div class="sc-cropper__preview">
|
|||
|
<h4>图像预览</h4>
|
|||
|
<div class="sc-cropper__preview__img" ref="preview"></div>
|
|||
|
</div>
|
|||
|
</div>
|
|||
|
</template>
|
|||
|
|
|||
|
<script>
|
|||
|
import Cropper from 'cropperjs'
|
|||
|
import 'cropperjs/dist/cropper.css'
|
|||
|
|
|||
|
export default {
|
|||
|
props: {
|
|||
|
src: { type: String, default: "" },
|
|||
|
compress: {type: Number, default: 1},
|
|||
|
aspectRatio: {type: Number, default: NaN},
|
|||
|
},
|
|||
|
data() {
|
|||
|
return {
|
|||
|
crop: null
|
|||
|
}
|
|||
|
},
|
|||
|
watch:{
|
|||
|
aspectRatio(val){
|
|||
|
this.crop.setAspectRatio(val)
|
|||
|
}
|
|||
|
},
|
|||
|
mounted() {
|
|||
|
this.init()
|
|||
|
},
|
|||
|
methods: {
|
|||
|
init(){
|
|||
|
this.crop = new Cropper(this.$refs.img, {
|
|||
|
viewMode: 2,
|
|||
|
dragMode: 'move',
|
|||
|
responsive: false,
|
|||
|
aspectRatio: this.aspectRatio,
|
|||
|
preview: this.$refs.preview
|
|||
|
})
|
|||
|
},
|
|||
|
setAspectRatio(aspectRatio){
|
|||
|
this.crop.setAspectRatio(aspectRatio)
|
|||
|
},
|
|||
|
getCropData(cb, type='image/jpeg'){
|
|||
|
cb(this.crop.getCroppedCanvas().toDataURL(type, this.compress))
|
|||
|
},
|
|||
|
getCropBlob(cb, type='image/jpeg'){
|
|||
|
this.crop.getCroppedCanvas().toBlob((blob) => {
|
|||
|
cb(blob)
|
|||
|
}, type, this.compress)
|
|||
|
},
|
|||
|
getCropFile(cb, fileName='fileName.jpg', type='image/jpeg'){
|
|||
|
this.crop.getCroppedCanvas().toBlob((blob) => {
|
|||
|
let file = new File([blob], fileName, {type: type})
|
|||
|
cb(file)
|
|||
|
}, type, this.compress)
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
</script>
|
|||
|
|
|||
|
<style scoped>
|
|||
|
.sc-cropper {height:300px;}
|
|||
|
.sc-cropper__img {height:100%;width:400px;float: left;background: #EBEEF5;}
|
|||
|
.sc-cropper__img img {display: none;}
|
|||
|
.sc-cropper__preview {width: 120px;margin-left: 20px;float: left;}
|
|||
|
.sc-cropper__preview h4 {font-weight: normal;font-size: 12px;color: #999;margin-bottom: 20px;}
|
|||
|
.sc-cropper__preview__img {overflow: hidden;width: 120px;height: 120px;border: 1px solid #ebeef5;}
|
|||
|
</style>
|