浏览代码

Compute total number of LineStyleRuns in advance.

/main
Yuncong Zhang 6 年前
当前提交
92a0cf40
共有 2 个文件被更改,包括 73 次插入25 次删除
  1. 14
      Runtime/ui/txt/linebreaker.cs
  2. 84
      Runtime/ui/txt/paragraph.cs

14
Runtime/ui/txt/linebreaker.cs


const float ScoreInfty = float.MaxValue;
const float ScoreDesperate = 1e10f;
int _lineLimit = 0;
// Limit number of lines, 0 means no limit
public int lineLimit {
get { return this._lineLimit; }
set { this._lineLimit = value; }
}
public static LineBreaker instance {
get {
if(_instance == null)

}
void _pushBreak(int offset, float width) {
this._breaks.Add(offset);
this._widths.Add(width);
if (this.lineLimit == 0 || this._breaks.Count < this.lineLimit) {
this._breaks.Add(offset);
this._widths.Add(width);
}
}
}
}

84
Runtime/ui/txt/paragraph.cs


float[] _lineHeights;
GlyphPosition[] glyphPositions;
int _lineCount;
List<PaintRecord> _paintRecords = new List<PaintRecord>();
List<CodeUnitRun> _codeUnitRuns = new List<CodeUnitRun>();
PaintRecord[] _paintRecords;
CodeUnitRun[] _codeUnitRuns;
int _paintRecordsCount;
int _codeUnitRunsCount;
bool _didExceedMaxLines;
TabStops _tabStops = new TabStops();

}
public void paint(Canvas canvas, Offset offset) {
foreach (var paintRecord in this._paintRecords) {
for (int i = 0; i < this._paintRecordsCount; i++) {
var paintRecord = this._paintRecords[i];
foreach (var paintRecord in this._paintRecords) {
for (int i = 0; i < this._paintRecordsCount; i++) {
var paintRecord = this._paintRecords[i];
var paint = new Paint {
filterMode = FilterMode.Bilinear,
color = paintRecord.style.color

this._needsLayout = false;
this._width = Mathf.Floor(constraints.width);
this._paintRecords.Clear();
this._codeUnitRuns.Clear();
this._computeLineBreak();
int lineStyleRunsCount = this._computeLineBreak();
if (this._glyphLines == null || this._glyphLines.Length < this._lineRanges.Count) {
this._glyphLines = new GlyphLine[this._lineRanges.Count];
}

this._lineHeights = new float[this._lineRanges.Count];
}
if (this._paintRecords == null || this._paintRecords.Length < lineStyleRunsCount) {
this._paintRecords = new PaintRecord[lineStyleRunsCount];
}
this._paintRecordsCount = 0;
if (this._codeUnitRuns == null || this._codeUnitRuns.Length < lineStyleRunsCount) {
this._codeUnitRuns = new CodeUnitRun[lineStyleRunsCount];
}
this._codeUnitRunsCount = 0;
int styleMaxLines = this._paragraphStyle.maxLines ?? int.MaxValue;
this._didExceedMaxLines = this._lineRanges.Count > styleMaxLines;

var metrics = FontMetrics.fromFont(font, style.UnityFontSize);
PaintRecord paintRecord = new PaintRecord(style, runXOffset, 0, builder.make(),
metrics, advance);
this._paintRecords.Add(paintRecord);
this._paintRecords[this._paintRecordsCount++] = paintRecord;
this._codeUnitRuns.Add(new CodeUnitRun(
CodeUnitRun codeUnitRun = new CodeUnitRun(
lineNumber, TextDirection.ltr, glyphPositionStyleRunStart, textCount));
lineNumber, TextDirection.ltr, glyphPositionStyleRunStart, textCount);
this._codeUnitRuns[this._codeUnitRunsCount++] = codeUnitRun;
lineStyleRunIndex++;
}

if (lineStyleRunCount != 0) {
for (int i = 0; i < lineStyleRunCount; i++) {
var paintRecord = this._paintRecords[this._paintRecords.Count - i - 1];
var paintRecord = this._paintRecords[this._paintRecordsCount - i - 1];
updateLineMetrics(paintRecord.metrics, paintRecord.style.height);
}
}

this._glyphLines[lineNumber] =
new GlyphLine(this.glyphPositions, glyphPositionLineStart, count, nextLineStart - lineStart);
for (int i = 0; i < lineStyleRunCount; i++) {
var paintRecord = this._paintRecords[this._paintRecords.Count - 1 - i];
var paintRecord = this._paintRecords[this._paintRecordsCount - 1 - i];
this._paintRecords[this._paintRecords.Count - 1 - i] = paintRecord;
this._paintRecords[this._paintRecordsCount - 1 - i] = paintRecord;
}
}

return this._lineCount;
}
void _computeLineBreak() {
int _computeLineBreak() {
int lineLimit = this._paragraphStyle.ellipsized()
? this._paragraphStyle.maxLines ?? 1
: this._paragraphStyle.maxLines ?? 0;
var newLinePositions = LineBreaker.newLinePositions;
this._computeNewLinePositions(newLinePositions);

int countRuns = 0;
if (lineLimit != 0 && this._lineRanges.Count >= lineLimit) {
break;
}
var blockStart = newlineIndex > 0 ? newLinePositions[newlineIndex - 1] + 1 : 0;
var blockEnd = newLinePositions[newlineIndex];
var blockSize = blockEnd - blockStart;

}
if (lineLimit != 0 && this._lineRanges.Count >= lineLimit) {
break;
}
this._resetLineBreaker(lineBreaker, blockStart, blockSize);
runIndex = this._addStyleRuns(lineBreaker, runIndex, blockStart, blockEnd);
this._resetLineBreaker(lineBreaker, blockStart, blockSize,
lineLimit == 0 ? 0 : lineLimit - this._lineRanges.Count);
countRuns += this._addStyleRuns(lineBreaker, ref runIndex, blockStart, blockEnd);
this._updateBreaks(lineBreaker, breaksCount, blockStart);
countRuns += breaksCount - 1;
this._updateBreaks(lineBreaker, breaksCount, blockStart, blockEnd);
return countRuns;
}
void _addEmptyLine(int blockStart, int blockEnd) {

}
void _resetLineBreaker(LineBreaker lineBreaker, int blockStart, int blockSize) {
void _resetLineBreaker(LineBreaker lineBreaker, int blockStart, int blockSize, int lineLimit) {
lineBreaker.lineLimit = lineLimit;
int _addStyleRuns(LineBreaker lineBreaker, int runIndex, int blockStart, int blockEnd) {
int _addStyleRuns(LineBreaker lineBreaker, ref int runIndex, int blockStart, int blockEnd) {
int countRuns = 0;
while (runIndex < this._runs.size) {
var run = this._runs.getRun(runIndex);
if (run.start >= blockEnd) {

if (run.end < blockStart) {
if (lineBreaker.lineLimit != 0 && lineBreaker.getBreaks().Count >= lineBreaker.lineLimit) {
break;
}
if (run.end <= blockStart) {
runIndex++;
continue;
}

lineBreaker.addStyleRun(run.style, runStart, runEnd);
countRuns++;
if (run.end > blockEnd) {
break;

}
return runIndex;
return countRuns;
void _updateBreaks(LineBreaker lineBreaker, int breaksCount, int blockStart) {
void _updateBreaks(LineBreaker lineBreaker, int breaksCount, int blockStart, int blockEnd) {
List<int> breaks = lineBreaker.getBreaks();
List<float> widths = lineBreaker.getWidths();
for (int i = 0; i < breaksCount; ++i) {

bool hardBreak = i == breaksCount - 1;
bool hardBreak = lineEnd == blockEnd;
var lineEndIncludingNewline =
hardBreak && lineEnd < this._text.Length ? lineEnd + 1 : lineEnd;
var lineEndExcludingWhitespace = lineEnd;

正在加载...
取消
保存