Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
cacb9a00
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
cacb9a00
编写于
4月 17, 2018
作者:
A
Alex Dima
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fixes #27187: Keep the top-most visible line constant
上级
7d2d20a3
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
15 addition
and
46 deletion
+15
-46
src/vs/editor/browser/editorBrowser.ts
src/vs/editor/browser/editorBrowser.ts
+0
-5
src/vs/editor/common/commonCodeEditor.ts
src/vs/editor/common/commonCodeEditor.ts
+0
-7
src/vs/editor/common/viewModel/viewModelImpl.ts
src/vs/editor/common/viewModel/viewModelImpl.ts
+15
-30
src/vs/monaco.d.ts
src/vs/monaco.d.ts
+0
-4
未找到文件。
src/vs/editor/browser/editorBrowser.ts
浏览文件 @
cacb9a00
...
...
@@ -619,11 +619,6 @@ export interface ICodeEditor extends editorCommon.IEditor {
*/
getLayoutInfo
():
editorOptions
.
EditorLayoutInfo
;
/**
* Returns the range that is currently centered in the view port.
*/
getCenteredRangeInViewport
():
Range
;
/**
* Returns the ranges that are currently visible.
* Does not account for horizontal scrolling.
...
...
src/vs/editor/common/commonCodeEditor.ts
浏览文件 @
cacb9a00
...
...
@@ -253,13 +253,6 @@ export abstract class CommonCodeEditor extends Disposable {
}
}
public
getCenteredRangeInViewport
():
Range
{
if
(
!
this
.
hasView
)
{
return
null
;
}
return
this
.
viewModel
.
getCenteredRangeInViewport
();
}
public
getVisibleRanges
():
Range
[]
{
if
(
!
this
.
hasView
)
{
return
[];
...
...
src/vs/editor/common/viewModel/viewModelImpl.ts
浏览文件 @
cacb9a00
...
...
@@ -33,6 +33,7 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
private
readonly
configuration
:
editorCommon
.
IConfiguration
;
private
readonly
model
:
ITextModel
;
private
hasFocus
:
boolean
;
private
viewportStartLine
:
number
;
private
viewportStartLineTrackedRange
:
string
;
private
viewportStartLineTop
:
number
;
private
readonly
lines
:
IViewModelLinesCollection
;
...
...
@@ -41,8 +42,6 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
private
readonly
decorations
:
ViewModelDecorations
;
private
_centeredViewLine
:
number
;
constructor
(
editorId
:
number
,
configuration
:
editorCommon
.
IConfiguration
,
model
:
ITextModel
,
scheduleAtNextAnimationFrame
:
(
callback
:
()
=>
void
)
=>
IDisposable
)
{
super
();
...
...
@@ -50,6 +49,7 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
this
.
configuration
=
configuration
;
this
.
model
=
model
;
this
.
hasFocus
=
false
;
this
.
viewportStartLine
=
-
1
;
this
.
viewportStartLineTrackedRange
=
null
;
this
.
viewportStartLineTop
=
0
;
...
...
@@ -89,8 +89,6 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
}
}));
this
.
_centeredViewLine
=
-
1
;
this
.
decorations
=
new
ViewModelDecorations
(
this
.
editorId
,
this
.
model
,
this
.
configuration
,
this
.
lines
,
this
.
coordinatesConverter
);
this
.
_registerModelEvents
();
...
...
@@ -130,8 +128,12 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
private
_onConfigurationChanged
(
eventsCollector
:
viewEvents
.
ViewEventsCollector
,
e
:
IConfigurationChangedEvent
):
void
{
// We might need to restore the current centered view range, so save it (if available)
const
previousCenteredModelRange
=
this
.
getCenteredRangeInViewport
();
let
revealPreviousCenteredModelRange
=
false
;
let
previousViewportStartModelPosition
:
Position
=
null
;
if
(
this
.
viewportStartLine
!==
-
1
)
{
let
previousViewportStartViewPosition
=
new
Position
(
this
.
viewportStartLine
,
this
.
getLineMinColumn
(
this
.
viewportStartLine
));
previousViewportStartModelPosition
=
this
.
coordinatesConverter
.
convertViewPositionToModelPosition
(
previousViewportStartViewPosition
);
}
let
restorePreviousViewportStart
=
false
;
const
conf
=
this
.
configuration
.
editor
;
...
...
@@ -144,7 +146,7 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
if
(
this
.
viewLayout
.
getCurrentScrollTop
()
!==
0
)
{
// Never change the scroll position from 0 to something else...
re
vealPreviousCenteredModelRange
=
true
;
re
storePreviousViewportStart
=
true
;
}
}
...
...
@@ -157,17 +159,10 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
eventsCollector
.
emit
(
new
viewEvents
.
ViewConfigurationChangedEvent
(
e
));
this
.
viewLayout
.
onConfigurationChanged
(
e
);
if
(
revealPreviousCenteredModelRange
&&
previousCenteredModelRange
)
{
// modelLine -> viewLine
const
newCenteredViewRange
=
this
.
coordinatesConverter
.
convertModelRangeToViewRange
(
previousCenteredModelRange
);
// Send a reveal event to restore the centered content
eventsCollector
.
emit
(
new
viewEvents
.
ViewRevealRangeRequestEvent
(
newCenteredViewRange
,
viewEvents
.
VerticalRevealType
.
Center
,
false
,
editorCommon
.
ScrollType
.
Immediate
));
if
(
restorePreviousViewportStart
&&
previousViewportStartModelPosition
)
{
const
viewPosition
=
this
.
coordinatesConverter
.
convertModelPositionToViewPosition
(
previousViewportStartModelPosition
);
const
viewPositionTop
=
this
.
viewLayout
.
getVerticalOffsetForLineNumber
(
viewPosition
.
lineNumber
);
this
.
viewLayout
.
deltaScrollNow
(
0
,
viewPositionTop
-
this
.
viewportStartLineTop
);
}
}
...
...
@@ -247,7 +242,7 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
}
// Update the configuration and reset the centered view line
this
.
_centeredView
Line
=
-
1
;
this
.
viewportStart
Line
=
-
1
;
this
.
configuration
.
setMaxLineNumber
(
this
.
model
.
getLineCount
());
// Recover viewport
...
...
@@ -332,16 +327,6 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
}
}
public
getCenteredRangeInViewport
():
Range
{
if
(
this
.
_centeredViewLine
===
-
1
)
{
// Never got rendered or not rendered since last content change event
return
null
;
}
let
viewLineNumber
=
this
.
_centeredViewLine
;
let
currentCenteredViewRange
=
new
Range
(
viewLineNumber
,
this
.
getLineMinColumn
(
viewLineNumber
),
viewLineNumber
,
this
.
getLineMaxColumn
(
viewLineNumber
));
return
this
.
coordinatesConverter
.
convertViewRangeToModelRange
(
currentCenteredViewRange
);
}
public
getVisibleRanges
():
Range
[]
{
const
visibleViewRange
=
this
.
getCompletelyVisibleViewRange
();
const
visibleRange
=
this
.
coordinatesConverter
.
convertViewRangeToModelRange
(
visibleViewRange
);
...
...
@@ -458,9 +443,9 @@ export class ViewModel extends viewEvents.ViewEventEmitter implements IViewModel
* Gives a hint that a lot of requests are about to come in for these line numbers.
*/
public
setViewport
(
startLineNumber
:
number
,
endLineNumber
:
number
,
centeredLineNumber
:
number
):
void
{
this
.
_centeredViewLine
=
centeredLineNumber
;
this
.
lines
.
warmUpLookupCache
(
startLineNumber
,
endLineNumber
);
this
.
viewportStartLine
=
startLineNumber
;
let
position
=
this
.
coordinatesConverter
.
convertViewPositionToModelPosition
(
new
Position
(
startLineNumber
,
this
.
getLineMinColumn
(
startLineNumber
)));
this
.
viewportStartLineTrackedRange
=
this
.
model
.
_setTrackedRange
(
this
.
viewportStartLineTrackedRange
,
new
Range
(
position
.
lineNumber
,
position
.
column
,
position
.
lineNumber
,
position
.
column
),
TrackedRangeStickiness
.
NeverGrowsWhenTypingAtEdges
);
this
.
viewportStartLineTop
=
this
.
viewLayout
.
getVerticalOffsetForLineNumber
(
startLineNumber
);
...
...
src/vs/monaco.d.ts
浏览文件 @
cacb9a00
...
...
@@ -3782,10 +3782,6 @@ declare namespace monaco.editor {
* Get the layout info for the editor.
*/
getLayoutInfo
():
EditorLayoutInfo
;
/**
* Returns the range that is currently centered in the view port.
*/
getCenteredRangeInViewport
():
Range
;
/**
* Returns the ranges that are currently visible.
* Does not account for horizontal scrolling.
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录