/** * @author Mateusz */ ImageEditor.Resize = { initialize: function(element) { this.element = element; this.leftBoxConstraint = 1; this.topBoxConstraint = 0; this.getRelativeMousePos = ImageEditor.Resize.getRelativeMousePos.bind(this); var options = { resizeStop: ImageEditor.Resize.resizeStop.bind(this), onDrag: ImageEditor.Resize.onDrag.bind(this), onResize: ImageEditor.Resize.onResize.bind(this), getMousePos: ImageEditor.Resize.getMousePos.bind(this) }; new ImageEditor.Positioning.addBehaviour(this.element); this.imageContainerResize = new ImageEditor.Resizeable.initialize(element,options); this.imageContainerResize.setVisible(false); }, resizeStop: function(event) { if(ImageEditor.EventStack.getLastEventElement() != null) { var imageElement = $('image'); ImageEditor.EventStack.clearStack(); if(this.imageContainerResize.isEnabled) { if(this.imageContainerResize.originalWidth != imageElement.width || this.imageContainerResize.originalHeight != imageElement.height) { $('imageContainer').style.backgroundImage = 'url("")'; ImageEditor.imageTransformation.resize(imageElement.width,imageElement.height,ImageEditor.Resize.resizeCallback.bind(this)); ImageEditor.effects.disableRotate(); ImageEditor.crop.disable(); this.imageContainerResize.disable(); ImageEditor.imageHistory.disable(); } } } }, resizeCallback: function() { $('imageContainer').style.backgroundImage = 'url("' + $('image').src + '")'; }, onDrag: function() { if(this.element.getTop() < this.topBoxConstraint) this.element.style.top = this.topBoxConstraint + "px"; if(this.element.getLeft() < this.leftBoxConstraint) this.element.style.left = this.leftBoxConstraint + "px"; ImageEditor.imageBox.reCenterIndicator(); }, onResize: function(width,height) { $('image').style.width = width + "px"; $('image').style.height = height + "px"; }, getMousePos: function(event) { var relativeMouseX = this.getRelativeMousePos(event).x; var relativeMouseY = this.getRelativeMousePos(event).y; if(relativeMouseX <= this.leftBoxConstraint) x = this.leftBoxConstraint + this.element.getParentLeft(); else x = relativeMouseX + this.element.getParentLeft(); if(relativeMouseY <= this.topBoxConstraint) y = this.topBoxConstraint + this.element.getParentTop(); else y = relativeMouseY + this.element.getParentTop(); return {x: x,y: y}; }, getRelativeMousePos: function(event) { var relativeMouseX = Event.pointerX(event) + $('imageEditorContainer').scrollLeft - this.element.getParentLeft(); var relativeMouseY = Event.pointerY(event) + $('imageEditorContainer').scrollTop - this.element.getParentTop(); return {x: relativeMouseX,y: relativeMouseY}; } }