Проблема с изменением размера формы Konva после использования кеширования и фильтрации

Детали проекта

на основе node.js используйте vue.js / javascript convas для vue

Рабочий процесс проекта

Проект включает этап со слоями и формами в нем. Пользователь может загружать изображения, которые затем отображаются в Konva. Если пользователь запускает событие двойного щелчка по изображению, новый прямоугольник создается и помещается поверх изображения (связывается с изображением) для изменения масштаба изображения без масштабирования размера, только изображение в фоновом режиме (масштабирование). Пока все хорошо.

Проблема

Затем у меня есть кнопка для установки фильтра для выбранного элемента / изображения Konva следующим образом:

selectedNode.cache();
selectedNode.filters([Konva.Filters.Sepia]);
selectedNode.batchDraw();

После этого я не могу масштабировать изображение с помощью масштабного прямоугольника. Я прочитал, что кеш преобразовал элемент konva в изображение, и после этого его невозможно изменить размер снова.

Есть ли способ расшифровать изображение после применения фильтра? Чтобы его можно было снова масштабировать в Konvas?

Здесь я создаю форму:

imageObj.onload = function() {

    ...

    clip = new Konva.Circle({
      id: 'clip_'+vm.anzClip,
      name: selectedNode.attrs.name,
      radius: max_size,
      x: selectedNode.attrs.x + max_size * selectedNode.attrs.scaleX,
      y: selectedNode.attrs.y + max_size * selectedNode.attrs.scaleY,
      draggable: true,
      uploadCutText: this.selectImgToolboxTextareaText,
      gravur: tempgrav,
      scaleX: selectedNode.attrs.scaleX,
      scaleY: selectedNode.attrs.scaleY,
      rotation: selectedNode.attrs.rotation,
      formType: 'circle',

      fillPatternImage: selectedNode.attrs.image,
      fillPatternOffset: { 
        x: max_size / patternScaleX, 
        y:  max_size / patternScaleY},
      fillPatternRepeat: 'no-repeat',
      fillPatternRotation: 0,
      fillPatternScale: {
        x:patternScaleX,
        y:patternScaleY,
      },
      dataScale: patternScaleX * selectedNode.attrs.scaleX,              
    });

      ...
      layer.add(clip);
      transformerNode.attachTo(clip);
      ...

DoubleClick событие для изменения масштаба изображения с наложением Rect:

clip.on('dblclick', function(e){


    transformerNode.attrs.enabledAnchors = ['top-left', 'top-right', 'bottom-left', 'bottom-right'];

        var selectedNode = e.target;

        if(typeof( selectedNode ) !== 'undefined'){

        if(Number.isNaN(selectedNode.attrs.fillPatternOffsetX) ){
            selectedNode.attrs.fillPatternOffsetX = 0;
        }
        if(Number.isNaN(selectedNode.attrs.fillPatternOffsetY) ){
            selectedNode.attrs.fillPatternOffsetY = 0;
        }

        let degto = 3.141592654 / 180;
        let sinr = Math.cos( selectedNode.attrs.rotation * degto) ;
        let cosr = Math.sin( selectedNode.attrs.rotation * degto );


        if (sinr > 1){
            sinr = 1;
        } else if( sinr < -1) {
            sinr = -1;
        } else if( sinr < 0 && sinr > -0.1) {
            sinr = 0;
        } else if( sinr > 0 && sinr < 0.1) {
            sinr = 0;
        }


        let xpart = 0;
        let xpartfill = 0;
        let ypart = 0;
        let width = 0;
        let height = 0;
        let xme = 1;
        let yme = 1;
        let scaleCenter = true;
        let setFillPatternScaleX = 1;
        let setFillPatternScaleY = 1;



        if(selectedNode.getClassName() === 'Rect'){

            console.log('clip.on(dblclick -> rect');


            width = selectedNode.attrs.width;
            height = selectedNode.attrs.height;

            xme = selectedNode.attrs.x 
            - selectedNode.attrs.fillPatternOffsetX * sinr * selectedNode.attrs.scaleX * selectedNode.attrs.fillPatternScaleX
            + selectedNode.attrs.fillPatternOffsetY * cosr * selectedNode.attrs.scaleY * selectedNode.attrs.fillPatternScaleY;
            yme = selectedNode.attrs.y 
            - selectedNode.attrs.fillPatternOffsetY * sinr * selectedNode.attrs.scaleY * selectedNode.attrs.fillPatternScaleY
            - selectedNode.attrs.fillPatternOffsetX * cosr * selectedNode.attrs.scaleX * selectedNode.attrs.fillPatternScaleX;
            scaleCenter = false;

            setFillPatternScaleX = 1;
            setFillPatternScaleY = 1;

        } 
        else {               

            console.log('clip.on(dblclick -> cirlce');

            width = selectedNode.attrs.radius * 2;
            height = selectedNode.attrs.radius * 2;
            xme = selectedNode.attrs.x 
            - selectedNode.attrs.fillPatternOffsetX * sinr * selectedNode.attrs.fillPatternScaleX * selectedNode.attrs.scaleX
            + selectedNode.attrs.fillPatternOffsetY * cosr * selectedNode.attrs.fillPatternScaleX * selectedNode.attrs.scaleX
            ;

            yme = selectedNode.attrs.y 
            - selectedNode.attrs.fillPatternOffsetY * sinr * selectedNode.attrs.fillPatternScaleY * selectedNode.attrs.scaleY
            - selectedNode.attrs.fillPatternOffsetX * cosr * selectedNode.attrs.fillPatternScaleY * selectedNode.attrs.scaleY
            ;
            scaleCenter = true;

            setFillPatternScaleX = selectedNode.attrs.fillPatternScaleX;
            setFillPatternScaleY = selectedNode.attrs.fillPatternScaleY;
        }

        let startx=0;
        let starty=0;


        // special - trans
        var rect = new Konva.Rect({
            id: 'special_trans',
            name: 'special_trans',
            width: selectedNode.attrs.fillPatternImage.width * selectedNode.attrs.scaleX,
            height: selectedNode.attrs.fillPatternImage.height * selectedNode.attrs.scaleY,
            x: xme,
            y: yme,
            // + max_size * selectedNode.attrs.scaleY,
            scaleX:selectedNode.attrs.fillPatternScaleX,
            scaleY:selectedNode.attrs.fillPatternScaleY,
            rotation:selectedNode.attrs.rotation,
            fillPatternOffsetX: 0,
            fillPatternOffsetY: 0,
            fillPatternScaleX: 1,
            fillPatternScaleY: 1,

            fill: 'red',
            stroke: 'black',
            strokeWidth: 0,
            opacity:.5,
            draggable: true,
            centeredScaling: scaleCenter,

        });


        layer.add(rect);                  
        layer.batchDraw();

        transformerNode.detach();
        transformerNode.attachTo(rect);    
        transformerNode.rotateEnabled(false);
        transformerNode.centeredScaling(true);


        let changeNodeName = 'clip_'+vm.anzClip;    
        vm.changeNode = selectedNode;


        rect.on('transform', function(e){    
            const { selectedShapeName } = vm;
            const selectedNode = stage.findOne('.' + selectedShapeName);

            e.currentTarget.attrs.rotation = selectedNode.attrs.rotation;
            e.currentTarget.attrs.fillPatternScaleX = setFillPatternScaleX;
            e.currentTarget.attrs.fillPatternScaleY = setFillPatternScaleY;
            vm.changeNode.attrs.fillPatternScaleX = e.currentTarget.attrs.scaleX;
            vm.changeNode.attrs.fillPatternScaleY = e.currentTarget.attrs.scaleY;    

            vm.changeNode.attrs.dataScale = vm.changeNode.attrs.dataScale;              
            layer.batchDraw();              

        });



        rect.on('dragmove', function(e){

            let xx = ( 
            - e.target.attrs.x / vm.changeNode.attrs.fillPatternScaleX 
            + vm.changeNode.attrs.x / vm.changeNode.attrs.fillPatternScaleX ) / vm.changeNode.attrs.scaleX;

            let yy = ( - e.target.attrs.y / vm.changeNode.attrs.fillPatternScaleY + vm.changeNode.attrs.y / vm.changeNode.attrs.fillPatternScaleY ) / vm.changeNode.attrs.scaleY;
            let degto = 3.141592654 / 180;
            let sinr = Math.cos( vm.changeNode.attrs.rotation * degto) ;
            let cosr = Math.sin(vm.changeNode.attrs.rotation * degto );

            if(vm.changeNode.attrs.rotation < 0){
            sinr = sinr;
            cosr = - cosr;

            vm.changeNode.attrs.fillPatternOffsetX =  xx * sinr - yy * cosr;  
            vm.changeNode.attrs.fillPatternOffsetY =  xx * cosr + yy * sinr;

            }else if (vm.changeNode.attrs.rotation < 90){
            sinr = sinr;
            cosr = cosr;

            vm.changeNode.attrs.fillPatternOffsetX = xx * sinr + yy * cosr;
            vm.changeNode.attrs.fillPatternOffsetY = yy * sinr - xx * cosr;

            }else if (vm.changeNode.attrs.rotation < 180){
            sinr = sinr;
            cosr = - cosr;

            vm.changeNode.attrs.fillPatternOffsetX =  xx * sinr - yy * cosr;
            vm.changeNode.attrs.fillPatternOffsetY =  xx * cosr + yy * sinr;

            }else{
            sinr = sinr;
            cosr = - cosr;

            vm.changeNode.attrs.fillPatternOffsetX =  xx * sinr + yy * cosr;
            vm.changeNode.attrs.fillPatternOffsetY =  xx * cosr - yy * sinr;

            }

            // transformerNode.parent Same OK


            vm.$nextTick(function(){
            transformerNode.parent.batchDraw();
            layer.batchDraw();
            });


        ...

0 ответов

Другие вопросы по тегам