Vue Filepond Изображение Crop

Я использую filepond с VueJS для загрузки изображений. Я должен обрезать изображения при загрузке, если я хочу.

Я зарегистрировал плагин filepond по всему миру.

import Vue from 'vue';
import vueFilePond from 'vue-filepond';
import FilePondPluginFileValidateType from 'filepond-plugin-file-validate-type';
import FilePondPluginImagePreview from 'filepond-plugin-image-preview';
import FilePondPluginImageCrop from 'filepond-plugin-image-crop';

import 'filepond/dist/filepond.min.css';
import 'filepond-plugin-image-preview/dist/filepond-plugin-image-preview.min.css';

const FilePond = vueFilePond(FilePondPluginFileValidateType, FilePondPluginImagePreview, FilePondPluginImageCrop);
Vue.component('filePond', FilePond);

Тогда я использую компонент

<file-pond
  name="image"
  ref="pond"
  :label-idle="$t('complaint_detail.label-idle')"
  :allow-multiple="false"
  accepted-file-types="image/*"
  :server="{ process }"
  :allowImagePreview="true"
  :allowImageCrop= "true"
  :allow-revert = "false"
  v-on:init="handleFilePondInit"
  v-on:addfile="handleFilePondAddFile"
/>

А вот мой process метод

process(fieldName, file, metadata, load) {
  load(file);
},
handleFilePondInit() {
  this.$refs.pond.getFiles();
},

Но с этими кодами обрезка изображения не работает. В документации есть только allowImageCrop, но он у меня не работает. Вот ссылка на документацию: https://pqina.nl/filepond/docs/patterns/plugins/image-crop/

1 ответ

Решение

Вам необходимо определить соотношение культур, используя imageCropAspectRatio имущество.

Для квадратного урожая:

<file-pond
  image-crop-aspect-ratio="1"
  name="image"
  ref="pond"
/>
Другие вопросы по тегам