mirror of
https://github.com/piskelapp/piskel.git
synced 2023-08-10 21:12:52 +03:00
df4978f6af
+ piskel deserialization is now clearly asynchronous + added utils.Deserializer (not a singleton though, more a builder/loader) + utils.Deserializer constructor expects a callback + when all layers are loaded and piskel is ready, the callback provided by the client is called with piskel as the first argument - Deserializer doesn't fit in the utils package, which should be reserved to singletons : can move it to service as a PiskelLoaderService, and Deserializer could remain with only the purely static methods - ImportController is realying on the Deserializer to build a Piskel but it shouldn't. Find a way to mutualize the code necessary to create a Piskel from an array of pskl.model.Frame - still cleanup to do in app.js - comments to add as well
173 lines
6.0 KiB
JavaScript
173 lines
6.0 KiB
JavaScript
(function () {
|
|
var ns = $.namespace('pskl.controller.settings');
|
|
var DEFAULT_FILE_STATUS = 'No file selected ...';
|
|
var PREVIEW_HEIGHT = 60;
|
|
|
|
ns.ImportController = function (piskelController) {
|
|
this.piskelController = piskelController;
|
|
this.importedImage_ = null;
|
|
};
|
|
|
|
ns.ImportController.prototype.init = function () {
|
|
this.importForm = $('[name=import-form]');
|
|
this.hiddenFileInput = $('[name=file-upload-input]');
|
|
this.fileInputButton = $('.file-input-button');
|
|
this.fileInputStatus = $('.file-input-status');
|
|
this.fileInputStatus.html(DEFAULT_FILE_STATUS);
|
|
|
|
this.importPreview = $('.import-section-preview');
|
|
|
|
this.resizeWidth = $('[name=resize-width]');
|
|
this.resizeHeight = $('[name=resize-height]');
|
|
this.smoothResize = $('[name=smooth-resize-checkbox]');
|
|
this.submitButton = $('[name=import-submit]');
|
|
|
|
this.importForm.submit(this.onImportFormSubmit_.bind(this));
|
|
this.hiddenFileInput.change(this.onFileUploadChange_.bind(this));
|
|
this.fileInputButton.click(this.onFileInputClick_.bind(this));
|
|
|
|
this.resizeWidth.keyup(this.onResizeInputKeyUp_.bind(this, 'width'));
|
|
this.resizeHeight.keyup(this.onResizeInputKeyUp_.bind(this, 'height'));
|
|
};
|
|
|
|
ns.ImportController.prototype.reset_ = function () {
|
|
this.importForm.get(0).reset();
|
|
this.fileInputStatus.html(DEFAULT_FILE_STATUS);
|
|
$.publish(Events.CLOSE_SETTINGS_DRAWER);
|
|
};
|
|
|
|
ns.ImportController.prototype.onResizeInputKeyUp_ = function (from, evt) {
|
|
if (this.importedImage_) {
|
|
this.synchronizeResizeFields_(evt.target.value, from);
|
|
}
|
|
};
|
|
|
|
ns.ImportController.prototype.synchronizeResizeFields_ = function (value, from) {
|
|
value = parseInt(value, 10);
|
|
if (isNaN(value)) {
|
|
value = 0;
|
|
}
|
|
var height = this.importedImage_.height, width = this.importedImage_.width;
|
|
if (from === 'width') {
|
|
this.resizeHeight.val(Math.round(value * height / width));
|
|
} else {
|
|
this.resizeWidth.val(Math.round(value * width / height));
|
|
}
|
|
};
|
|
|
|
ns.ImportController.prototype.onImportFormSubmit_ = function (evt) {
|
|
evt.originalEvent.preventDefault();
|
|
this.importImageToPiskel_();
|
|
};
|
|
|
|
ns.ImportController.prototype.onFileUploadChange_ = function (evt) {
|
|
this.importFromFile_();
|
|
};
|
|
|
|
ns.ImportController.prototype.onFileInputClick_ = function (evt) {
|
|
this.hiddenFileInput.click();
|
|
};
|
|
|
|
ns.ImportController.prototype.importFromFile_ = function () {
|
|
var files = this.hiddenFileInput.get(0).files;
|
|
if (files.length == 1) {
|
|
var file = files[0];
|
|
if (this.isImage_(file)) {
|
|
this.readImageFile_(file);
|
|
this.enableDisabledSections_();
|
|
} else {
|
|
this.reset_();
|
|
throw 'File is not an image : ' + file.type;
|
|
}
|
|
}
|
|
};
|
|
|
|
ns.ImportController.prototype.enableDisabledSections_ = function () {
|
|
this.resizeWidth.removeAttr('disabled');
|
|
this.resizeHeight.removeAttr('disabled');
|
|
this.smoothResize.removeAttr('disabled');
|
|
this.submitButton.removeAttr('disabled');
|
|
|
|
this.fileInputButton.removeClass('button-primary');
|
|
this.fileInputButton.blur();
|
|
|
|
$('.import-section-disabled').removeClass('import-section-disabled');
|
|
};
|
|
|
|
ns.ImportController.prototype.readImageFile_ = function (imageFile) {
|
|
pskl.utils.FileUtils.readFile(imageFile, this.processImageSource_.bind(this));
|
|
};
|
|
|
|
/**
|
|
* Create an image from the given source (url or data-url), and onload forward to onImageLoaded
|
|
* TODO : should be a generic utility method, should take a callback
|
|
* @param {String} imageSource url or data-url, will be used as src for the image
|
|
*/
|
|
ns.ImportController.prototype.processImageSource_ = function (imageSource) {
|
|
this.importedImage_ = new Image();
|
|
this.importedImage_.onload = this.onImageLoaded_.bind(this);
|
|
this.importedImage_.src = imageSource;
|
|
};
|
|
|
|
ns.ImportController.prototype.onImageLoaded_ = function (evt) {
|
|
var w = this.importedImage_.width,
|
|
h = this.importedImage_.height;
|
|
var filePath = this.hiddenFileInput.val();
|
|
var fileName = this.extractFileNameFromPath_(filePath);
|
|
this.fileInputStatus.html(fileName);
|
|
|
|
this.resizeWidth.val(w);
|
|
this.resizeHeight.val(h);
|
|
|
|
this.importPreview.width('auto');
|
|
this.importPreview.html('');
|
|
this.importPreview.append(this.createImagePreview_());
|
|
};
|
|
|
|
ns.ImportController.prototype.createImagePreview_ = function () {
|
|
var image = document.createElement('IMG');
|
|
image.src = this.importedImage_.src;
|
|
image.setAttribute('height', PREVIEW_HEIGHT);
|
|
return image;
|
|
};
|
|
|
|
ns.ImportController.prototype.extractFileNameFromPath_ = function (path) {
|
|
var parts = [];
|
|
if (path.indexOf('/') !== -1) {
|
|
parts = path.split('/');
|
|
} else if (path.indexOf('\\') !== -1) {
|
|
parts = path.split('\\');
|
|
} else {
|
|
parts = [path];
|
|
}
|
|
return parts[parts.length-1];
|
|
};
|
|
|
|
ns.ImportController.prototype.importImageToPiskel_ = function () {
|
|
if (this.importedImage_) {
|
|
if (window.confirm('You are about to create a new Piskel, unsaved changes will be lost.')) {
|
|
var w = this.resizeWidth.val(),
|
|
h = this.resizeHeight.val(),
|
|
smoothing = !!this.smoothResize.prop('checked');
|
|
|
|
var image = pskl.utils.ImageResizer.resize(this.importedImage_, w, h, smoothing);
|
|
var frame = pskl.utils.FrameUtils.createFromImage(image);
|
|
|
|
// TODO : juliandescottes : here we only want to create a layer from an array of frames, and create a new piskel using this layer
|
|
// we shouldn't use the deserializer for this ... it's only working because it's falling back to the old implementation
|
|
// bad, very bad
|
|
var deserializer = new pskl.utils.Deserializer([frame], function (piskel) {
|
|
pskl.app.piskelController.setPiskel(piskel);
|
|
pskl.app.animationController.setFPS(Constants.DEFAULT.FPS);
|
|
this.reset_();
|
|
}.bind(this));
|
|
deserializer.deserialize();
|
|
}
|
|
}
|
|
};
|
|
|
|
ns.ImportController.prototype.isImage_ = function (file) {
|
|
return file.type.indexOf('image') === 0;
|
|
};
|
|
|
|
})(); |