better dragging.

This commit is contained in:
Christopher Jeffrey 2015-04-08 00:50:46 -07:00
parent 78e663a734
commit 95364dd229
2 changed files with 98 additions and 61 deletions

View File

@ -507,6 +507,7 @@ The base element.
- __enableKeys()__ - enable keypress events for the element (automatically called when a form of on('keypress') is bound). - __enableKeys()__ - enable keypress events for the element (automatically called when a form of on('keypress') is bound).
- __enableInput()__ - enable key and mouse events. calls bot enableMouse and enableKeys. - __enableInput()__ - enable key and mouse events. calls bot enableMouse and enableKeys.
- __enableDrag()__ - enable dragging of the element. - __enableDrag()__ - enable dragging of the element.
- __disableDrag()__ - disable dragging of the element.
###### Content Methods ###### Content Methods

View File

@ -2668,34 +2668,31 @@ Element.prototype.enableDrag = function() {
this.enableMouse(); this.enableMouse();
this.on('mousedown', this._dragMD = function(data) { this.on('mousedown', this._dragMD = function(data) {
var el = self if (self._drag) return;
, x = data.x self._drag = {
, y = data.y; x: data.x - self.aleft,
y: data.y - self.atop
while (el = el.parent) { };
x -= el.rleft;
y -= el.rtop;
}
self._drag = { x: x, y: y };
}); });
this.screen.on('mouse', this._dragM = function(data) { this.screen.on('mouse', this._dragM = function(data) {
if (!self._drag) return;
if (data.action !== 'mousedown') { if (data.action !== 'mousedown') {
delete self._drag; delete self._drag;
return; return;
} }
if (self._drag) {
var ox = self._drag.x; var ox = self._drag.x
var oy = self._drag.y; , oy = self._drag.y
var px = self.parent.aleft; , px = self.parent.aleft
var py = self.parent.atop; , py = self.parent.atop
var x = data.x - px; , x = data.x - px - ox
var y = data.y - py; , y = data.y - py - oy;
self.rleft = x;
self.rtop = y; self.rleft = x;
self.screen.render(); self.rtop = y;
} self.screen.render();
}); });
return this._draggable = true; return this._draggable = true;
@ -3766,6 +3763,31 @@ Element.prototype.render = function() {
, i , i
, bch = this.ch; , bch = this.ch;
// Clip content if it's off the edge of the screen
// if (xi + this.ileft < 0 || yi + this.itop < 0) {
// var clines = this._clines.slice();
// if (xi + this.ileft < 0) {
// for (var i = 0; i < clines.length; i++) {
// var t = 0;
// var csi = '';
// var csis = '';
// for (var j = 0; j < clines[i].length; j++) {
// while (clines[i][j] === '\x1b') {
// csi = '\x1b';
// while (clines[i][j++] !== 'm') csi += clines[i][j];
// csis += csi;
// }
// if (++t === -(xi + this.ileft) + 1) break;
// }
// clines[i] = csis + clines[i].substring(j);
// }
// }
// if (yi + this.itop < 0) {
// clines = clines.slice(-(yi + this.itop));
// }
// content = clines.join('\n');
// }
if (coords.base >= this._clines.ci.length) { if (coords.base >= this._clines.ci.length) {
ci = this._pcontent.length; ci = this._pcontent.length;
} }
@ -3839,10 +3861,22 @@ Element.prototype.render = function() {
// Draw the content and background. // Draw the content and background.
for (y = yi; y < yl; y++) { for (y = yi; y < yl; y++) {
if (!lines[y]) break; if (!lines[y]) {
if (y >= this.screen.height || yl < this.ibottom) {
break;
} else {
continue;
}
}
for (x = xi; x < xl; x++) { for (x = xi; x < xl; x++) {
cell = lines[y][x]; cell = lines[y][x];
if (!cell) break; if (!cell) {
if (x >= this.screen.width || xl < this.iright) {
break;
} else {
continue;
}
}
ch = content[ci++] || bch; ch = content[ci++] || bch;
@ -4025,47 +4059,49 @@ Element.prototype.render = function() {
for (; y < yl - 1; y++) { for (; y < yl - 1; y++) {
if (!lines[y]) continue; if (!lines[y]) continue;
cell = lines[y][xi]; cell = lines[y][xi];
if (!cell) continue; if (cell) {
if (this.border.left) { if (this.border.left) {
if (this.border.type === 'line') { if (this.border.type === 'line') {
ch = '\u2502'; // '│' ch = '\u2502'; // '│'
} else if (this.border.type === 'bg') { } else if (this.border.type === 'bg') {
ch = this.border.ch; ch = this.border.ch;
} }
if (!coords.noleft) if (!coords.noleft)
if (battr !== cell[0] || ch !== cell[1]) { if (battr !== cell[0] || ch !== cell[1]) {
lines[y][xi][0] = battr; lines[y][xi][0] = battr;
lines[y][xi][1] = ch; lines[y][xi][1] = ch;
lines[y].dirty = true; lines[y].dirty = true;
} }
} else { } else {
ch = ' '; ch = ' ';
if (dattr !== cell[0] || ch !== cell[1]) { if (dattr !== cell[0] || ch !== cell[1]) {
lines[y][xi][0] = dattr; lines[y][xi][0] = dattr;
lines[y][xi][1] = ch; lines[y][xi][1] = ch;
lines[y].dirty = true; lines[y].dirty = true;
}
} }
} }
cell = lines[y][xl - 1]; cell = lines[y][xl - 1];
if (!cell) continue; if (cell) {
if (this.border.right) { if (this.border.right) {
if (this.border.type === 'line') { if (this.border.type === 'line') {
ch = '\u2502'; // '│' ch = '\u2502'; // '│'
} else if (this.border.type === 'bg') { } else if (this.border.type === 'bg') {
ch = this.border.ch; ch = this.border.ch;
} }
if (!coords.noright) if (!coords.noright)
if (battr !== cell[0] || ch !== cell[1]) { if (battr !== cell[0] || ch !== cell[1]) {
lines[y][xl - 1][0] = battr; lines[y][xl - 1][0] = battr;
lines[y][xl - 1][1] = ch; lines[y][xl - 1][1] = ch;
lines[y].dirty = true; lines[y].dirty = true;
} }
} else { } else {
ch = ' '; ch = ' ';
if (dattr !== cell[0] || ch !== cell[1]) { if (dattr !== cell[0] || ch !== cell[1]) {
lines[y][xl - 1][0] = dattr; lines[y][xl - 1][0] = dattr;
lines[y][xl - 1][1] = ch; lines[y][xl - 1][1] = ch;
lines[y].dirty = true; lines[y].dirty = true;
}
} }
} }
} }