mirror of
https://github.com/piskelapp/piskel.git
synced 2023-08-10 21:12:52 +03:00
152 lines
4.9 KiB
JavaScript
152 lines
4.9 KiB
JavaScript
(function () {
|
|
var ns = $.namespace('pskl.devtools');
|
|
|
|
ns.DrawingTestPlayer = function (testRecord, step) {
|
|
this.initialState = testRecord.initialState;
|
|
this.events = testRecord.events;
|
|
this.referencePng = testRecord.png;
|
|
this.step = step || ns.DrawingTestPlayer.DEFAULT_STEP;
|
|
this.callbacks = [];
|
|
this.shim = null;
|
|
};
|
|
|
|
ns.DrawingTestPlayer.DEFAULT_STEP = 50;
|
|
|
|
ns.DrawingTestPlayer.prototype.start = function () {
|
|
this.setupInitialState_();
|
|
this.createMouseShim_();
|
|
this.regenerateReferencePng().then(function () {
|
|
this.playEvent_(0);
|
|
}.bind(this));
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.setupInitialState_ = function () {
|
|
var size = this.initialState.size;
|
|
var piskel = this.createPiskel_(size.width, size.height);
|
|
pskl.app.piskelController.setPiskel(piskel);
|
|
|
|
$.publish(Events.SELECT_PRIMARY_COLOR, [this.initialState.primaryColor]);
|
|
$.publish(Events.SELECT_SECONDARY_COLOR, [this.initialState.secondaryColor]);
|
|
$.publish(Events.SELECT_TOOL, [this.initialState.selectedTool]);
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.createPiskel_ = function (width, height) {
|
|
var descriptor = new pskl.model.piskel.Descriptor('TestPiskel', '');
|
|
var piskel = new pskl.model.Piskel(width, height, descriptor);
|
|
var layer = new pskl.model.Layer('Layer 1');
|
|
var frame = new pskl.model.Frame(width, height);
|
|
|
|
layer.addFrame(frame);
|
|
piskel.addLayer(layer);
|
|
|
|
return piskel;
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.regenerateReferencePng = function () {
|
|
var image = new Image();
|
|
var then = function () {};
|
|
|
|
image.onload = function () {
|
|
this.referencePng = pskl.utils.CanvasUtils.createFromImage(image).toDataURL();
|
|
then();
|
|
}.bind(this);
|
|
image.src = this.referencePng;
|
|
|
|
return {
|
|
then : function (cb) {
|
|
then = cb;
|
|
}
|
|
};
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.createMouseShim_ = function () {
|
|
this.shim = document.createElement('DIV');
|
|
this.shim.style.cssText = 'position:fixed;top:0;left:0;right:0;left:0;bottom:0;z-index:15000';
|
|
this.shim.addEventListener('mousemove', function (e) {
|
|
e.stopPropagation();
|
|
e.preventDefault();
|
|
}, true);
|
|
document.body.appendChild(this.shim);
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.removeMouseShim_ = function () {
|
|
this.shim.parentNode.removeChild(this.shim);
|
|
this.shim = null;
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.playEvent_ = function (index) {
|
|
this.timer = window.setTimeout(function () {
|
|
var recordEvent = this.events[index];
|
|
|
|
if (recordEvent.type === 'mouse-event') {
|
|
this.playMouseEvent_(recordEvent);
|
|
} else if (recordEvent.type === 'color-event') {
|
|
this.playColorEvent_(recordEvent);
|
|
} else if (recordEvent.type === 'tool-event') {
|
|
this.playToolEvent_(recordEvent);
|
|
} else if (recordEvent.type === 'instrumented-event') {
|
|
this.playInstrumentedEvent_(recordEvent);
|
|
}
|
|
|
|
if (this.events[index + 1]) {
|
|
this.playEvent_(index + 1);
|
|
} else {
|
|
this.onTestEnd_();
|
|
}
|
|
}.bind(this), this.step);
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.playMouseEvent_ = function (recordEvent) {
|
|
var event = recordEvent.event;
|
|
var screenCoordinates = pskl.app.drawingController.getScreenCoordinates(recordEvent.coords.x, recordEvent.coords.y);
|
|
event.clientX = screenCoordinates.x;
|
|
event.clientY = screenCoordinates.y;
|
|
if (pskl.utils.UserAgent.isMac && event.ctrlKey) {
|
|
event.metaKey = true;
|
|
}
|
|
|
|
if (event.type == 'mousedown') {
|
|
pskl.app.drawingController.onMousedown_(event);
|
|
} else if (event.type == 'mouseup') {
|
|
pskl.app.drawingController.onMouseup_(event);
|
|
} else if (event.type == 'mousemove') {
|
|
pskl.app.drawingController.onMousemove_(event);
|
|
}
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.playColorEvent_ = function (recordEvent) {
|
|
if (recordEvent.isPrimary) {
|
|
$.publish(Events.SELECT_PRIMARY_COLOR, [recordEvent.color]);
|
|
} else {
|
|
$.publish(Events.SELECT_SECONDARY_COLOR, [recordEvent.color]);
|
|
}
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.playToolEvent_ = function (recordEvent) {
|
|
$.publish(Events.SELECT_TOOL, [recordEvent.toolId]);
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.playInstrumentedEvent_ = function (recordEvent) {
|
|
pskl.app.piskelController[recordEvent.methodName].apply(pskl.app.piskelController, recordEvent.args);
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.onTestEnd_ = function () {
|
|
this.removeMouseShim_();
|
|
|
|
var renderer = new pskl.rendering.PiskelRenderer(pskl.app.piskelController);
|
|
var png = renderer.renderAsCanvas().toDataURL();
|
|
|
|
var success = png === this.referencePng;
|
|
|
|
$.publish(Events.TEST_RECORD_END, [success, png, this.referencePng]);
|
|
this.callbacks.forEach(function (callback) {
|
|
callback(success, png, this.referencePng);
|
|
});
|
|
};
|
|
|
|
ns.DrawingTestPlayer.prototype.addEndTestCallback = function (callback) {
|
|
this.callbacks.push(callback);
|
|
};
|
|
|
|
})();
|