/*
 * @provide pskl.drawingtools.SimplePen
 *
 * @require pskl.utils
 */
(function() {
	var ns = $.namespace("pskl.drawingtools");

	ns.SimplePen = function() {
		this.toolId = "tool-pen"
	};

	this.previousCol = null;
	this.previousRow = null;

	pskl.utils.inherit(ns.SimplePen, ns.BaseTool);
	
	/**
	 * @override
	 */
	ns.SimplePen.prototype.applyToolAt = function(col, row, frame, color, canvas, dpi) {
		
		this.previousCol = col;
		this.previousRow = row;

		// Change model:
		var color = pskl.utils.normalizeColor(color);
	    if (color != frame[col][row]) {
	        frame[col][row] = color;
	    }

	    // Draw on canvas:
	    // TODO: Remove that when we have the centralized redraw loop
	    this.drawPixelInCanvas(col, row, canvas, color, dpi);
	};

	ns.SimplePen.prototype.moveToolAt = function(col, row, frame, color, canvas, dpi) {
		
		if((Math.abs(col - this.previousCol) > 1) || (Math.abs(row - this.previousRow) > 1)) {
			// The pen movement is too fast for the mousemove frequency, there is a gap between the
			// current point and the previously drawn one.
			// We fill the gap by calculating missing dots (simple linear interpolation) and draw them.
			var interpolatedPixels = this.getLinePixels_(col, this.previousCol, row, this.previousRow);
			for(var i=0, l=interpolatedPixels.length; i<l; i++) {
				this.applyToolAt(interpolatedPixels[i].col, interpolatedPixels[i].row, frame, color, canvas, dpi);
			}
		}
		else {
			this.applyToolAt(col, row, frame, color, canvas, dpi);
		}

		this.previousCol = col;
		this.previousRow = row;
	};

	ns.SimplePen.prototype.releaseToolAt = function(col, row, frame, color, canvas, dpi) {
		// TODO: Create a afterRelease event hook or out that deep in the model
		$.publish(Events.FRAMESHEET_UPDATED);   
	};
})();