mirror of
https://github.com/embarklabs/neo-blessed.git
synced 2025-01-25 18:29:26 +00:00
check scrollable elements for "clean" sides for CSR rendering.
This commit is contained in:
parent
95848bafa3
commit
fd5bd89d56
@ -651,6 +651,53 @@ Screen.prototype.deleteTop = function(top, bottom) {
|
|||||||
return this.deleteLine(1, top, top, bottom);
|
return this.deleteLine(1, top, top, bottom);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Not exactly sure how worthwile this is.
|
||||||
|
// This will cause a performance/cpu-usage hit,
|
||||||
|
// but will it be less or greater than the
|
||||||
|
// performance hit of slow-rendering scrollable
|
||||||
|
// boxes with clean sides?
|
||||||
|
Screen.prototype.cleanSides = function(el) {
|
||||||
|
if (!el._lastPos) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
var pos = el._lastPos
|
||||||
|
, yi = pos.yi + (el.border ? 1 : 0) + el.padding
|
||||||
|
, yl = pos.yl - (el.border ? 1 : 0) - el.padding
|
||||||
|
, first = this.olines[yi][pos.xi - 1]
|
||||||
|
, ch
|
||||||
|
, x
|
||||||
|
, y;
|
||||||
|
|
||||||
|
if (pos._cleanSides != null) {
|
||||||
|
return pos._cleanSides;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pos.xi === 0 && pos.xl === this.width) {
|
||||||
|
return pos._cleanSides = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (; y < yl; y++) {
|
||||||
|
for (x = pos.xi - 1; x >= 0; x--) {
|
||||||
|
ch = this.olines[y][x];
|
||||||
|
if (ch[0] !== first[0] || ch[1] !== first[1]) {
|
||||||
|
return pos._cleanSides = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (; y < yl; y++) {
|
||||||
|
for (x = pos.xl; x < this.width; x++) {
|
||||||
|
ch = this.olines[y][x];
|
||||||
|
if (ch[0] !== first[0] || ch[1] !== first[1]) {
|
||||||
|
return pos._cleanSides = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return pos._cleanSides = true;
|
||||||
|
};
|
||||||
|
|
||||||
Screen.prototype.draw = function(start, end) {
|
Screen.prototype.draw = function(start, end) {
|
||||||
var x
|
var x
|
||||||
, y
|
, y
|
||||||
@ -1960,6 +2007,7 @@ outer:
|
|||||||
|
|
||||||
Box.prototype.insertLine = function(i, line) {
|
Box.prototype.insertLine = function(i, line) {
|
||||||
//if (typeof line === 'string') line = [line];
|
//if (typeof line === 'string') line = [line];
|
||||||
|
// if (this.screen.cleanSides(this)) {
|
||||||
if (this._lastPos && this._lastPos.xi === 0 && this._lastPos.xl === this.screen.width) {
|
if (this._lastPos && this._lastPos.xi === 0 && this._lastPos.xl === this.screen.width) {
|
||||||
i = Math.max(i, 0);
|
i = Math.max(i, 0);
|
||||||
i = Math.min(i, this._lastPos.yl - this._lastPos.yi - (this.border ? 2 : 0) - this.padding * 2);
|
i = Math.min(i, this._lastPos.yl - this._lastPos.yi - (this.border ? 2 : 0) - this.padding * 2);
|
||||||
@ -1980,6 +2028,7 @@ Box.prototype.insertLine = function(i, line) {
|
|||||||
Box.prototype.deleteLine = function(i) {
|
Box.prototype.deleteLine = function(i) {
|
||||||
//if (typeof line === 'string') line = [line];
|
//if (typeof line === 'string') line = [line];
|
||||||
var reset = true;
|
var reset = true;
|
||||||
|
// if (this.screen.cleanSides(this)) {
|
||||||
if (this._lastPos && this._lastPos.xi === 0 && this._lastPos.xl === this.screen.width) {
|
if (this._lastPos && this._lastPos.xi === 0 && this._lastPos.xl === this.screen.width) {
|
||||||
i = Math.max(i, 0);
|
i = Math.max(i, 0);
|
||||||
i = Math.min(i, this._lastPos.yl - this._lastPos.yi - (this.border ? 2 : 0) - this.padding * 2);
|
i = Math.min(i, this._lastPos.yl - this._lastPos.yi - (this.border ? 2 : 0) - this.padding * 2);
|
||||||
@ -2156,6 +2205,7 @@ ScrollableBox.prototype.scroll = function(offset) {
|
|||||||
|
|
||||||
// Optimize scrolling with CSR + IL/DL.
|
// Optimize scrolling with CSR + IL/DL.
|
||||||
p = this._lastPos;
|
p = this._lastPos;
|
||||||
|
// if (this.childBase !== base && this.screen.cleanSides(this)) {
|
||||||
if (this.childBase !== base && p && (p.xl - p.xi) === this.screen.width) {
|
if (this.childBase !== base && p && (p.xl - p.xi) === this.screen.width) {
|
||||||
t = p.yi + (this.border ? 1 : 0) + this.padding;
|
t = p.yi + (this.border ? 1 : 0) + this.padding;
|
||||||
b = p.yl - (this.border ? 1 : 0) - this.padding - 1;
|
b = p.yl - (this.border ? 1 : 0) - this.padding - 1;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user