mirror of
https://github.com/piskelapp/piskel.git
synced 2023-08-10 21:12:52 +03:00
107 lines
3.4 KiB
JavaScript
107 lines
3.4 KiB
JavaScript
/*
|
|
* @provide pskl.ToolSelector
|
|
*
|
|
* @require Constants
|
|
* @require Events
|
|
* @require pskl.drawingtools
|
|
*/
|
|
$.namespace("pskl");
|
|
|
|
pskl.ToolSelector = (function() {
|
|
|
|
var toolInstances = {
|
|
"simplePen" : new pskl.drawingtools.SimplePen(),
|
|
"eraser" : new pskl.drawingtools.Eraser(),
|
|
"paintBucket" : new pskl.drawingtools.PaintBucket(),
|
|
"stroke" : new pskl.drawingtools.Stroke(),
|
|
"rectangle" : new pskl.drawingtools.Rectangle(),
|
|
"circle" : new pskl.drawingtools.Circle(),
|
|
"move" : new pskl.drawingtools.Move(),
|
|
"rectangleSelect" : new pskl.drawingtools.RectangleSelect(),
|
|
"shapeSelect" : new pskl.drawingtools.ShapeSelect()
|
|
};
|
|
|
|
var currentSelectedTool = toolInstances.simplePen;
|
|
var previousSelectedTool = toolInstances.simplePen;
|
|
|
|
var activateToolOnStage_ = function(tool) {
|
|
var stage = $("body");
|
|
var previousSelectedToolClass = stage.data("selected-tool-class");
|
|
if(previousSelectedToolClass) {
|
|
stage.removeClass(previousSelectedToolClass);
|
|
}
|
|
stage.addClass(tool.toolId);
|
|
stage.data("selected-tool-class", tool.toolId);
|
|
};
|
|
|
|
var selectTool_ = function(tool) {
|
|
console.log("Selecting Tool:" , currentSelectedTool);
|
|
currentSelectedTool = tool;
|
|
activateToolOnStage_(currentSelectedTool);
|
|
$.publish(Events.TOOL_SELECTED, [tool]);
|
|
};
|
|
|
|
/**
|
|
* @private
|
|
*/
|
|
var onToolIconClicked_ = function(evt) {
|
|
var target = $(evt.target);
|
|
var clickedTool = target.closest(".tool-icon");
|
|
|
|
if(clickedTool.length) {
|
|
for(var tool in toolInstances) {
|
|
if (toolInstances[tool].toolId == clickedTool.data().toolId) {
|
|
selectTool_(toolInstances[tool]);
|
|
|
|
// Show tool as selected:
|
|
$('#menubar .tool-icon.selected').removeClass('selected');
|
|
clickedTool.addClass('selected');
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
/**
|
|
* @private
|
|
*/
|
|
var createToolMarkup_ = function() {
|
|
var currentTool, toolMarkup = '';
|
|
for (var toolKey in toolInstances) {
|
|
currentTool = toolInstances[toolKey];
|
|
toolMarkup += '<li class="tool-icon ' + currentTool.toolId + '" data-tool-id="' + currentTool.toolId
|
|
+ '" title="' + currentTool.helpText + '"></li>';
|
|
}
|
|
$('#tools-container').html(toolMarkup);
|
|
};
|
|
|
|
/**
|
|
* Get state for the checkbox that control the display of the grid
|
|
* on the drawing canvas.
|
|
* @private
|
|
*/
|
|
var isShowGridChecked_ = function() {
|
|
var showGridCheckbox = $('#show-grid');
|
|
var isChecked = showGridCheckbox.is(':checked');
|
|
return isChecked;
|
|
};
|
|
|
|
return {
|
|
init: function() {
|
|
|
|
createToolMarkup_();
|
|
|
|
// Initialize tool:
|
|
// Set SimplePen as default selected tool:
|
|
selectTool_(toolInstances.simplePen);
|
|
// Activate listener on tool panel:
|
|
$("#menubar").click(onToolIconClicked_);
|
|
|
|
// Show/hide the grid on drawing canvas:
|
|
$.publish(Events.GRID_DISPLAY_STATE_CHANGED, [isShowGridChecked_()]);
|
|
$('#show-grid').change(function(evt) {
|
|
var checked = isShowGridChecked_();
|
|
$.publish(Events.GRID_DISPLAY_STATE_CHANGED, [checked]);
|
|
});
|
|
}
|
|
};
|
|
})(); |