目录引言图片裁剪图片裁剪的流程Vue-cropperjs的使用代码实现实现效果v-viewer的使用代码实现实现效果最后引言 做了个图片的裁剪的功能和预览的功能,前端图片的裁剪方案,
做了个图片的裁剪的功能和预览的功能,前端图片的裁剪方案,大多数都是用cropperjs进行封装,npm上有vue-cropperjs可以直接用起来,viewerjs是用来实现图片的预览,这里直接使用了v-viewer来实现。
可以点击现在地址体验喔
git仓库地址 以及在线demo地址
// 引入组件并注册
import "cropperjs/dist/cropper.CSS";
import VueCropper from "vue-cropperjs";
// 直接使用组件
<vue-cropper
overflow-hidden
ref="cropper"
:src="src"
preview=".preview"
:minContainerHeight="500"
background
:ready="onReady"
/>
// 图片可以在onReady方法中设置裁剪的宽高比例
this.$refs.cropper.setAspectRatio(this.aspectRatioValue);
// 缩放图片
this.$refs.cropper.relativeZoom(percent);
// 图片旋转角度
this.onRotateDegreeChange(this.rotateDegree);
// 图片平移
this.$refs.cropper.move(offsetX, offsetY);
// 图片翻转
this.$refs.cropper.scaleX(scale);
this.$refs.cropper.scaleY(scale);
// 重置
this.$refs.cropper.reset();
// 获取修改后的图片的数据
this.$refs.cropper
.getCroppedCanvas({
// 限制画布大小,限制生成的图片体积
maxWidth: 2056,
maxHeight: 2056,
})
.toBlob(
(blob) => {
// 调用确定的回调函数,将blob上传到服务器或者本地预览
this.$emit("confirm", blob);
},
// 如果旋转角度不为直角,则图片一定会出现空白区域,空白区域默认透明,使用 png 格式
//this.rotateDegree % 90 === 0 ? this.file.type : 'image/png',
this.file.type,
// 质量
this.quality
);
// 将文件上传到服务器
function onCropperConfirm(blob) {
let file = new File([blob], filename, { type: blob.type,});
const fORMData = new FormData();
formData.append("file", file);
// ...
axiOS.post("/upload", formData).then((res) => {
// ...
})
}
v-viewer主要的实现图片的全屏预览,基于viewerjs封装
// 首先在main.js中引入组件
import "viewerjs/dist/viewer.css";
import VueViewer from "v-viewer";
Vue.use(VueViewer);
// 组件中使用
this.$viewerApi({
options: {
toolbar: true,
initialViewIndex: 1,
},
images: [
"https://placem.at/people?random=1&txt=0&w=500&h=500",
"Https://placem.at/people?random=1&txt=0&w=1000&h=500"
],
});
参考资料
www.npmjs.com/package/v-v…
www.npmjs.com/package/vue…
推荐 js前端实现Word excel pdf ppt mp4图片文本等文件预览
图片剪裁使用插件实现的话,只能说CV工程师不要太爽,要了解原理的话,还是需要花费很多时间研究的;更多关于前端vue-cropperjs图片裁剪的资料请关注编程网其它相关文章!
--结束END--
本文标题: 前端vue-cropperjs实现图片裁剪方案
本文链接: https://lsjlt.com/news/153919.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-01-12
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0