本文整理汇总了TypeScript中vs/editor/browser/viewLayout/layoutProvider.LayoutProvider.getLinesViewportData方法的典型用法代码示例。如果您正苦于以下问题:TypeScript LayoutProvider.getLinesViewportData方法的具体用法?TypeScript LayoutProvider.getLinesViewportData怎么用?TypeScript LayoutProvider.getLinesViewportData使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类vs/editor/browser/viewLayout/layoutProvider.LayoutProvider
的用法示例。
在下文中一共展示了LayoutProvider.getLinesViewportData方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: Error
visibleRangeForPositionRelativeToEditor: (lineNumber: number, column: number) => {
if (this._isDisposed) {
throw new Error('ViewImpl.keyboardHandler.visibleRangeForPositionRelativeToEditor: View is disposed');
}
this._flushAccumulatedAndRenderNow();
let linesViewPortData = this.layoutProvider.getLinesViewportData();
let visibleRanges = this.viewLines.visibleRangesForRange2(new Range(lineNumber, column, lineNumber, column), linesViewPortData.visibleRangesDeltaTop);
if (!visibleRanges) {
return null;
}
return visibleRanges[0];
},
示例2: getCompletelyVisibleLinesRangeInViewport
public getCompletelyVisibleLinesRangeInViewport(): Range {
if (this._isDisposed) {
throw new Error('ViewImpl.getCompletelyVisibleLinesRangeInViewport: View is disposed');
}
let partialData = this.layoutProvider.getLinesViewportData();
let startLineNumber = partialData.startLineNumber === partialData.endLineNumber || partialData.relativeVerticalOffset[0] >= partialData.viewportTop ? partialData.startLineNumber : partialData.startLineNumber + 1;
let endLineNumber = partialData.relativeVerticalOffset[partialData.relativeVerticalOffset.length - 1] + this._context.configuration.editor.lineHeight <= partialData.viewportTop + partialData.viewportHeight ? partialData.endLineNumber : partialData.endLineNumber - 1;
let completelyVisibleLinesRange = new Range(
startLineNumber,
1,
endLineNumber,
this._context.model.getLineMaxColumn(endLineNumber)
);
return this._context.model.coordinatesConverter.convertViewRangeToModelRange(completelyVisibleLinesRange);
}
示例3: _actualRender
private _actualRender(): void {
if (!dom.isInDOM(this.domNode.domNode)) {
return;
}
let viewPartsToRender = this._getViewPartsToRender();
if (!this.viewLines.shouldRender() && viewPartsToRender.length === 0) {
// Nothing to render
this.keyboardHandler.writeToTextArea();
return;
}
let partialViewportData = this.layoutProvider.getLinesViewportData();
this._context.model.setViewport(partialViewportData.startLineNumber, partialViewportData.endLineNumber, partialViewportData.centeredLineNumber);
let viewportData = new ViewportData(partialViewportData, this._context.model);
if (this.viewLines.shouldRender()) {
this.viewLines.renderText(viewportData, () => {
this.keyboardHandler.writeToTextArea();
});
this.viewLines.onDidRender();
// Rendering of viewLines might cause scroll events to occur, so collect view parts to render again
viewPartsToRender = this._getViewPartsToRender();
} else {
this.keyboardHandler.writeToTextArea();
}
let renderingContext = new RenderingContext(this.viewLines, this.layoutProvider, viewportData);
// Render the rest of the parts
for (let i = 0, len = viewPartsToRender.length; i < len; i++) {
let viewPart = viewPartsToRender[i];
viewPart.prepareRender(renderingContext);
}
for (let i = 0, len = viewPartsToRender.length; i < len; i++) {
let viewPart = viewPartsToRender[i];
viewPart.render(renderingContext);
viewPart.onDidRender();
}
}