tools/fliphorizontal.js
function flipHorizontalTool(toolbar) {
"use strict";
var canvas, ctx, startX, startY, oldEndX, oldEndY;
function selectionPattern() {
var patternCanvas, patternCtx, halfWidth, halfHeight;
patternCanvas = ElementHelper.create("canvas", {"width": toolbar.codepage.fontHeight, "height": toolbar.codepage.fontHeight});
halfWidth = patternCanvas.width / 2;
halfHeight = patternCanvas.height / 2;
patternCtx = patternCanvas.getContext("2d");
patternCtx.fillStyle = "rgb(255, 255, 255)";
patternCtx.fillRect(0, 0, halfWidth, halfHeight);
patternCtx.fillRect(halfWidth, halfHeight, halfWidth, halfHeight);
patternCtx.fillStyle = "rgb(0, 0, 0)";
patternCtx.fillRect(halfWidth, 0, halfWidth, halfHeight);
patternCtx.fillRect(0, halfHeight, halfWidth, halfHeight);
return patternCanvas;
}
canvas = ElementHelper.create("canvas", {"width": 80 * toolbar.codepage.fontWidth, "height": toolbar.editor.height * toolbar.codepage.fontHeight});
ctx = canvas.getContext("2d");
ctx.strokeStyle = ctx.createPattern(selectionPattern(), "repeat");
ctx.lineWidth = toolbar.codepage.fontWidth / 2;
function translateCoords(fromTextX, fromTextY, toTextX, toTextY) {
var textX, textY, width, height;
if (toTextX < fromTextX) {
textX = toTextX;
width = (fromTextX - toTextX + 1);
} else {
textX = fromTextX;
width = (toTextX - fromTextX + 1);
}
if (toTextY < fromTextY) {
textY = toTextY;
height = (fromTextY - toTextY + 1);
} else {
textY = fromTextY;
height = (toTextY - fromTextY + 1);
}
return {
"textX": textX,
"textY": textY,
"width": width,
"height": height
};
}
function canvasDown(evt) {
startX = evt.detail.textX;
startY = evt.detail.textY;
}
function clearSelection() {
var coords;
if (oldEndX !== undefined && oldEndY !== undefined) {
coords = translateCoords(startX, startY, oldEndX, oldEndY);
ctx.clearRect(coords.textX * toolbar.codepage.fontWidth, coords.textY * toolbar.codepage.fontHeight, coords.width * toolbar.codepage.fontWidth, coords.height * toolbar.codepage.fontHeight);
}
}
function canvasDrag(evt) {
var coords;
clearSelection();
coords = translateCoords(startX, startY, evt.detail.textX, evt.detail.textY);
ctx.strokeRect(coords.textX * toolbar.codepage.fontWidth + ctx.lineWidth, coords.textY * toolbar.codepage.fontHeight + ctx.lineWidth, coords.width * toolbar.codepage.fontWidth - ctx.lineWidth * 2, coords.height * toolbar.codepage.fontHeight - ctx.lineWidth * 2);
oldEndX = evt.detail.textX;
oldEndY = evt.detail.textY;
}
function canvasUp(evt) {
var coords, x, y, blocks;
clearSelection();
coords = translateCoords(startX, startY, evt.detail.textX, evt.detail.textY);
toolbar.editor.takeUndoSnapshot();
for (y = 0; y < coords.height; ++y) {
blocks = [];
for (x = 0; x < coords.width; ++x) {
blocks.push(toolbar.editor.getTextBlock(coords.textX + x, coords.textY + y));
}
for (x = 0; x < coords.width; ++x) {
toolbar.editor.setTextBlock(blocks[coords.width - (x + 1)], blocks[x].charCode, blocks[x].foreground, blocks[x].background);
}
}
}
function init() {
toolbar.editor.canvas.addEventListener("canvasDown", canvasDown, false);
toolbar.editor.canvas.addEventListener("canvasDrag", canvasDrag, false);
toolbar.editor.canvas.addEventListener("canvasUp", canvasUp, false);
toolbar.editor.addOverlay(canvas, "flip-horizontal");
return true;
}
function remove() {
toolbar.editor.canvas.removeEventListener("canvasDown", canvasDown);
toolbar.editor.canvas.removeEventListener("canvasDrag", canvasDrag);
toolbar.editor.canvas.removeEventListener("canvasUp", canvasUp);
toolbar.editor.removeOverlay("flip-horizontal");
}
function toString() {
return "Flip Horizontally";
}
return {
"init": init,
"remove": remove,
"toString": toString,
"uid": "flip-horizontal"
};
}
AnsiEditController.addTool(flipHorizontalTool);