2017-09-15 51 views
1

在自由繪圖模式下使用FabricJS和Angular2時,我面臨的一個問題是,無論我繪製的任何對象最終都會向左或向上移動。例如,我開始畫在畫布此垂直線: See the location of the line during mouse down面料JS + Angular2:在自由繪圖模式下鼠標向上移動的對象

當我完成後,所產生的行結束了在這張照片上移,如: After mouse up, the line shifted to left

我已搜查直通谷歌,但它似乎很少或幾乎沒有遇到這個問題。這隻有在自由繪畫模式下才會發生。有沒有什麼我做錯了我設置畫布或面料js的方式?

下面是我的HTML模板以及組件代碼:

import {AfterViewInit, Component, ElementRef, Input, OnChanges, OnInit, ViewChild} from '@angular/core'; 
 
declare var fabric: any; 
 

 
@Component({ 
 
    selector: 'app-fabric-canvas', 
 
    templateUrl: './fabric-canvas.component.html', 
 
    styleUrls: ['./fabric-canvas.component.css'] 
 
}) 
 
export class FabricCanvasComponent implements OnInit, OnChanges, AfterViewInit { 
 
    public canvas: any; 
 
    @ViewChild('canvas') canvasRef: ElementRef; 
 
    @ViewChild('fileInput') fileInput: ElementRef; 
 
    @ViewChild('divWrapper') divWrapper: ElementRef; 
 
    @Input() public color: string; 
 
    @Input() public id: string; 
 
    private selectedFile: File; 
 
    private fileReader: FileReader = new FileReader(); 
 
    public disableModifyObjectButton = true; 
 
    public disableAddImageButton = true; 
 
    public textColor = 'black'; 
 
    public selectedObject: any; 
 
    public pencilBrush: any; 
 
    public svg: string; 
 

 
    constructor() { } 
 

 
    ngOnInit() { 
 
    } 
 

 
    ngOnChanges() { 
 
    } 
 

 
    ngAfterViewInit() { 
 
    if (!this.canvas) { 
 
     this.canvas = new fabric.Canvas(this.id); 
 
     this.canvas.selection = false; 
 
     this.canvas.preserveObjectStacking = true; 
 
     this.pencilBrush = new fabric.PencilBrush(this.canvas); 
 
     this.canvas.freeDrawingBrush = this.pencilBrush; 
 
     this.canvas.freeDrawingBrush.color = 'red'; 
 
     this.canvas.freeDrawingBrush.width = 10; 
 
     // this.canvas.isDrawingMode = true; 
 
     this.canvas.on('object:selected', (object) => { 
 
     this.selectedObject = object.target; 
 
     this.disableModifyObjectButton = false; 
 
     }); 
 
     this.canvas.on('selection:cleared',() => { 
 
     this.selectedObject = null; 
 
     this.disableModifyObjectButton = true; 
 
     }); 
 
     const height = this.divWrapper.nativeElement.offsetWidth * 1.33333; 
 
     this.canvas.setWidth(this.divWrapper.nativeElement.offsetWidth); 
 
     this.canvas.setHeight(height); 
 
    } 
 
    } 
 

 
    fileSelected() { 
 
    if (this.fileInput.nativeElement.files.length) { 
 
     this.disableAddImageButton = false; 
 
    } else { 
 
     this.disableAddImageButton = true; 
 
    } 
 
    } 
 

 
    onColorChange() { 
 
    if (this.selectedObject) { 
 
     this.selectedObject.setColor(this.selectedObject.fill); 
 
     this.canvas.renderAll(); 
 
    } 
 
    } 
 

 
    addImageButton() { 
 
    if (this.fileInput.nativeElement.files.length) { 
 
     this.selectedFile = this.fileInput.nativeElement.files[0]; 
 
     this.fileReader.readAsDataURL(this.selectedFile); 
 
     this.fileReader.onload = () => { 
 
     this.fileInput.nativeElement.value = null; 
 
     this.disableAddImageButton = true; 
 
     this.addImageToCanvas(this.fileReader.result); 
 
     } 
 
    } 
 
    } 
 

 
    toggleDrawingMode() { 
 
    this.canvas.isDrawingMode = !this.canvas.isDrawingMode; 
 
    } 
 

 
    addTextToCanvas(text: string) { 
 
    const textObject = new fabric.IText(text, { 
 
     top: 10, left: 10, fill: 'black' 
 
    }); 
 
    this.canvas.add(textObject); 
 
    } 
 

 
    addImageToCanvas(dataUrl: string) { 
 
    fabric.Image.fromURL(dataUrl, img => { 
 
     this.canvas.add(img); 
 
    }, { 
 
     top: 10, left: 10 
 
    }); 
 
    } 
 

 
    deleteSelectedObjects() { 
 
    if (this.canvas) { 
 
     this.canvas.remove(this.selectedObject); 
 
    } 
 
    } 
 

 
    bringForwardSelectedObject() { 
 
    if (this.canvas) { 
 
     this.canvas.bringForward(this.selectedObject); 
 
    } 
 
    } 
 

 
    sendBackwardSelectedObject() { 
 
    if (this.canvas) { 
 
     this.canvas.sendBackwards(this.selectedObject); 
 
    } 
 
    } 
 

 
    saveToSvg() { 
 
    this.svg = this.canvas.toDataURL(); 
 
    } 
 
}
<div class="container-fluid" *ngIf="id"> 
 
    <div class="row"> 
 
    <div class="col form-group form-inline"> 
 
     <input #fileInput class="form-control form-control-sm mr-sm-1" 
 
      (change)="fileSelected()" 
 
      type="file" 
 
      accept="image/png, image/jpeg"/> 
 
     <button class="btn btn-sm btn-primary mr-sm-1" (click)="addImageButton()" [disabled]="disableAddImageButton">Add Image</button> 
 
     <button class="btn btn-sm btn-primary mr-sm-1" (click)="addTextToCanvas('Text Entry')">Add Text</button> 
 
     <button (click)="toggleDrawingMode()">Draw</button> 
 
    </div> 
 
    </div> 
 
    <div class="row"> 
 
    <div class="col form-group"> 
 
     <button class="btn btn-sm btn-danger btn-block" 
 
       (click)="deleteSelectedObjects()" 
 
       [disabled]="disableModifyObjectButton">Remove</button> 
 
    </div> 
 
    <div class="col form-group"> 
 
     <button class="btn btn-sm btn-danger btn-block" 
 
       (click)="bringForwardSelectedObject()" 
 
       [disabled]="disableModifyObjectButton">Bring Forward</button> 
 
    </div> 
 
    <div class="col form-group"> 
 
     <button class="btn btn-sm btn-danger btn-block" 
 
       (click)="sendBackwardSelectedObject()" 
 
       [disabled]="disableModifyObjectButton">Send Back</button> 
 
    </div> 
 
    <div class="col form-group" *ngIf="this.selectedObject"> 
 
     <select class="form-control form-control-sm" 
 
       [disabled]="!this.selectedObject.text" 
 
       [(ngModel)]="this.selectedObject.fill" 
 
       (change)="onColorChange()"> 
 
     <option [value]="'black'" style="background-color: black; color: transparent;">Black</option> 
 
     <option [value]="'red'" style="background-color: red; color: transparent;">Red</option> 
 
     <option [value]="'blue'" style="background-color: blue; color: transparent;">Blue</option> 
 
     <option [value]="'green'" style="background-color: green; color: transparent;">Green</option> 
 
     <option [value]="'white'" style="background-color: white; color: transparent;">White</option> 
 
     </select> 
 
    </div> 
 
    </div> 
 
    <div class="row"> 
 
    <div class="col"> 
 
     <div #divWrapper> 
 
     <canvas [id]="id" #canvas></canvas> 
 
     </div> 
 
    </div> 
 
    </div> 
 
    <div class="row"> 
 
    <div class="col form-group"> 
 
     <button class="btn btn-primary" (click)="saveToSvg()">Save to SVG</button> 
 
    </div> 
 
    </div> 
 
    <div class="row"> 
 
    <div class="col"> 
 
     <img [src]="svg" class="img-fluid"> 
 
    </div> 
 
    </div> 
 
</div>

回答

0

你好這看起來像在同β7前的最新面料的錯誤。 更新應該解決。