Fixed proportions issue, thinned cells horizontally

This commit is contained in:
Lewis Hemens 2014-01-22 21:07:46 +00:00
parent 3da104f76c
commit 8225f9d074
2 changed files with 16 additions and 14 deletions

View File

@ -15,7 +15,9 @@ goog.provide('ascii');
/** @const */ var DRAG_LATENCY = 130; // Milliseconds. /** @const */ var DRAG_LATENCY = 130; // Milliseconds.
/** @const */ var DRAG_ACCURACY = 3; // Pixels. /** @const */ var DRAG_ACCURACY = 3; // Pixels.
/** @const */ var CHARACTER_PIXELS = 15; /** @const */ var CHAR_PIXELS_H = 11;
/** @const */ var CHAR_PIXELS_V = 15;
/** @const */ var RENDER_PADDING = 70; /** @const */ var RENDER_PADDING = 70;
/** @const */ var KEY_RETURN = '<enter>'; /** @const */ var KEY_RETURN = '<enter>';

View File

@ -69,19 +69,19 @@ ascii.View.prototype.render = function() {
context.beginPath(); context.beginPath();
for (var i = startOffset.x; i < endOffset.x; i++) { for (var i = startOffset.x; i < endOffset.x; i++) {
context.moveTo( context.moveTo(
i * CHARACTER_PIXELS - this.offset.x, i * CHAR_PIXELS_H - this.offset.x,
0 - this.offset.y); 0 - this.offset.y);
context.lineTo( context.lineTo(
i * CHARACTER_PIXELS - this.offset.x, i * CHAR_PIXELS_H - this.offset.x,
this.state.cells.length * CHARACTER_PIXELS - this.offset.y); this.state.cells.length * CHAR_PIXELS_V - this.offset.y);
} }
for (var j = startOffset.y; j < endOffset.y; j++) { for (var j = startOffset.y; j < endOffset.y; j++) {
context.moveTo( context.moveTo(
0 - this.offset.x, 0 - this.offset.x,
j * CHARACTER_PIXELS - this.offset.y); j * CHAR_PIXELS_V - this.offset.y);
context.lineTo( context.lineTo(
this.state.cells.length * CHARACTER_PIXELS - this.offset.x, this.state.cells.length * CHAR_PIXELS_H - this.offset.x,
j * CHARACTER_PIXELS - this.offset.y); j * CHAR_PIXELS_V - this.offset.y);
} }
this.context.stroke(); this.context.stroke();
@ -93,16 +93,16 @@ ascii.View.prototype.render = function() {
if (cell.hasScratch() || cell.isSpecial()) { if (cell.hasScratch() || cell.isSpecial()) {
this.context.fillStyle = cell.hasScratch() ? '#DEF' : '#F5F5F5'; this.context.fillStyle = cell.hasScratch() ? '#DEF' : '#F5F5F5';
context.fillRect( context.fillRect(
i * CHARACTER_PIXELS - this.offset.x, i * CHAR_PIXELS_H - this.offset.x,
(j - 1) * CHARACTER_PIXELS - this.offset.y, (j - 1) * CHAR_PIXELS_V - this.offset.y,
CHARACTER_PIXELS, CHARACTER_PIXELS); CHAR_PIXELS_H, CHAR_PIXELS_V);
} }
var cellValue = this.state.getDrawValue(new ascii.Vector(i, j)); var cellValue = this.state.getDrawValue(new ascii.Vector(i, j));
if (cellValue != null) { if (cellValue != null) {
this.context.fillStyle = '#000000'; this.context.fillStyle = '#000000';
context.fillText(cellValue, context.fillText(cellValue,
i * CHARACTER_PIXELS - this.offset.x + 3, i * CHAR_PIXELS_H - this.offset.x + 1,
j * CHARACTER_PIXELS - this.offset.y - 2); j * CHAR_PIXELS_V - this.offset.y - 3);
} }
} }
} }
@ -153,8 +153,8 @@ ascii.View.prototype.frameToScreen = function(vector) {
*/ */
ascii.View.prototype.frameToCell = function(vector) { ascii.View.prototype.frameToCell = function(vector) {
return new ascii.Vector( return new ascii.Vector(
Math.round((vector.x - CHARACTER_PIXELS / 2) / CHARACTER_PIXELS), Math.round((vector.x - CHAR_PIXELS_H / 2) / CHAR_PIXELS_H),
Math.round((vector.y + CHARACTER_PIXELS / 2) / CHARACTER_PIXELS)); Math.round((vector.y + CHAR_PIXELS_V / 2) / CHAR_PIXELS_V));
}; };
/** /**