本文整理匯總了TypeScript中vs/editor/common/view/renderingContext.IRenderingContext.visibleRangeForPosition方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript IRenderingContext.visibleRangeForPosition方法的具體用法?TypeScript IRenderingContext.visibleRangeForPosition怎麽用?TypeScript IRenderingContext.visibleRangeForPosition使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類vs/editor/common/view/renderingContext.IRenderingContext
的用法示例。
在下文中一共展示了IRenderingContext.visibleRangeForPosition方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: _layoutBoxInViewport
private _layoutBoxInViewport(position: Position, domNode: HTMLElement, ctx: IRenderingContext): IBoxLayoutResult {
let visibleRange = ctx.visibleRangeForPosition(position);
if (!visibleRange) {
return null;
}
let width = domNode.clientWidth;
let height = domNode.clientHeight;
// Our visible box is split horizontally by the current line => 2 boxes
// a) the box above the line
let aboveLineTop = visibleRange.top;
let heightAboveLine = aboveLineTop;
// b) the box under the line
let underLineTop = visibleRange.top + this._lineHeight;
let heightUnderLine = ctx.viewportHeight - underLineTop;
let aboveTop = aboveLineTop - height;
let fitsAbove = (heightAboveLine >= height);
let belowTop = underLineTop;
let fitsBelow = (heightUnderLine >= height);
// And its left
let actualLeft = visibleRange.left;
if (actualLeft + width > ctx.viewportLeft + ctx.viewportWidth) {
actualLeft = ctx.viewportLeft + ctx.viewportWidth - width;
}
if (actualLeft < ctx.viewportLeft) {
actualLeft = ctx.viewportLeft;
}
return {
aboveTop: aboveTop,
fitsAbove: fitsAbove,
belowTop: belowTop,
fitsBelow: fitsBelow,
left: actualLeft
};
}
示例2:
let fetchPlacement = () => {
if (placement) {
return;
}
const visibleRange = ctx.visibleRangeForPosition(position);
if (!visibleRange) {
return null;
}
const domNode = widgetData.domNode.domNode;
const width = domNode.clientWidth;
const height = domNode.clientHeight;
if (widgetData.allowEditorOverflow) {
placement = this._layoutBoxInPage(visibleRange, width, height, ctx);
} else {
placement = this._layoutBoxInViewport(visibleRange, width, height, ctx);
}
};