Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
74afb41c
V
vscode
项目概览
xxadev
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
74afb41c
编写于
2月 15, 2017
作者:
A
Alex Dima
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Have the minimap scroll such that its slider aligns (center) with the scrollbar slider
上级
27ec9ef5
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
41 addition
and
11 deletion
+41
-11
src/vs/base/browser/ui/scrollbar/abstractScrollbar.ts
src/vs/base/browser/ui/scrollbar/abstractScrollbar.ts
+1
-1
src/vs/base/browser/ui/scrollbar/scrollableElement.ts
src/vs/base/browser/ui/scrollbar/scrollableElement.ts
+4
-0
src/vs/base/browser/ui/scrollbar/scrollbarState.ts
src/vs/base/browser/ui/scrollbar/scrollbarState.ts
+4
-0
src/vs/base/browser/ui/scrollbar/verticalScrollbar.ts
src/vs/base/browser/ui/scrollbar/verticalScrollbar.ts
+4
-0
src/vs/editor/browser/view/viewImpl.ts
src/vs/editor/browser/view/viewImpl.ts
+1
-1
src/vs/editor/browser/viewParts/editorScrollbar/editorScrollbar.ts
...itor/browser/viewParts/editorScrollbar/editorScrollbar.ts
+4
-0
src/vs/editor/browser/viewParts/minimap/minimap.ts
src/vs/editor/browser/viewParts/minimap/minimap.ts
+23
-9
未找到文件。
src/vs/base/browser/ui/scrollbar/abstractScrollbar.ts
浏览文件 @
74afb41c
...
...
@@ -48,7 +48,7 @@ export abstract class AbstractScrollbar extends Widget {
protected
_host
:
ScrollbarHost
;
protected
_scrollable
:
Scrollable
;
private
_lazyRender
:
boolean
;
pr
ivate
_scrollbarState
:
ScrollbarState
;
pr
otected
_scrollbarState
:
ScrollbarState
;
private
_visibilityController
:
ScrollbarVisibilityController
;
private
_mouseMoveMonitor
:
GlobalMouseMoveMonitor
<
IStandardMouseMoveEventData
>
;
...
...
src/vs/base/browser/ui/scrollbar/scrollableElement.ts
浏览文件 @
74afb41c
...
...
@@ -145,6 +145,10 @@ export class ScrollableElement extends Widget {
this
.
_verticalScrollbar
.
delegateMouseDown
(
browserEvent
);
}
public
getVerticalSliderVerticalCenter
():
number
{
return
this
.
_verticalScrollbar
.
getVerticalSliderVerticalCenter
();
}
public
updateState
(
newState
:
INewScrollState
):
void
{
this
.
_scrollable
.
updateState
(
newState
);
}
...
...
src/vs/base/browser/ui/scrollbar/scrollbarState.ts
浏览文件 @
74afb41c
...
...
@@ -171,6 +171,10 @@ export class ScrollbarState {
return
this
.
_computedSliderPosition
;
}
public
getSliderCenter
():
number
{
return
(
this
.
_computedSliderPosition
+
this
.
_computedSliderSize
/
2
);
}
public
convertSliderPositionToScrollPosition
(
desiredSliderPosition
:
number
):
number
{
return
desiredSliderPosition
/
this
.
_computedRatio
;
}
...
...
src/vs/base/browser/ui/scrollbar/verticalScrollbar.ts
浏览文件 @
74afb41c
...
...
@@ -60,6 +60,10 @@ export class VerticalScrollbar extends AbstractScrollbar {
this
.
_createSlider
(
0
,
Math
.
floor
((
options
.
verticalScrollbarSize
-
options
.
verticalSliderSize
)
/
2
),
options
.
verticalSliderSize
,
null
);
}
public
getVerticalSliderVerticalCenter
():
number
{
return
this
.
_scrollbarState
.
getSliderCenter
();
}
protected
_updateSlider
(
sliderSize
:
number
,
sliderPosition
:
number
):
void
{
this
.
slider
.
setHeight
(
sliderSize
);
if
(
this
.
_canUseTranslate3d
)
{
...
...
src/vs/editor/browser/view/viewImpl.ts
浏览文件 @
74afb41c
...
...
@@ -271,7 +271,7 @@ export class View extends ViewEventHandler implements editorBrowser.IView, IDisp
let
rulers
=
new
Rulers
(
this
.
_context
);
this
.
viewParts
.
push
(
rulers
);
let
minimap
=
new
Minimap
(
this
.
_context
,
this
.
layoutProvider
);
let
minimap
=
new
Minimap
(
this
.
_context
,
this
.
layoutProvider
,
this
.
_scrollbar
);
this
.
viewParts
.
push
(
minimap
);
// -------------- Wire dom nodes up
...
...
src/vs/editor/browser/viewParts/editorScrollbar/editorScrollbar.ts
浏览文件 @
74afb41c
...
...
@@ -125,4 +125,8 @@ export class EditorScrollbar implements IDisposable {
public
delegateVerticalScrollbarMouseDown
(
browserEvent
:
MouseEvent
):
void
{
this
.
scrollbar
.
delegateVerticalScrollbarMouseDown
(
browserEvent
);
}
public
getVerticalSliderVerticalCenter
():
number
{
return
this
.
scrollbar
.
getVerticalSliderVerticalCenter
();
}
}
src/vs/editor/browser/viewParts/minimap/minimap.ts
浏览文件 @
74afb41c
...
...
@@ -22,6 +22,7 @@ import { ColorId } from 'vs/editor/common/modes';
import
{
FastDomNode
,
createFastDomNode
}
from
'
vs/base/browser/styleMutator
'
;
import
{
IDisposable
}
from
'
vs/base/common/lifecycle
'
;
// import { IViewLayout } from 'vs/editor/common/viewModel/viewModel';
import
{
EditorScrollbar
}
from
'
vs/editor/browser/viewParts/editorScrollbar/editorScrollbar
'
;
let
charRenderer2
=
createMinimapCharRenderer2
();
// TODO@minimap
...
...
@@ -121,7 +122,8 @@ class MinimapLayout {
viewportHeight
:
number
,
viewportStartLineNumber
:
number
,
viewportEndLineNumber
:
number
,
lineCount
:
number
lineCount
:
number
,
scrollbarSliderCenter
:
number
)
{
const
pixelRatio
=
options
.
pixelRatio
;
const
minimapLineHeight
=
(
options
.
renderMinimap
===
RenderMinimap
.
Large
?
Constants
.
x2_CHAR_HEIGHT
:
Constants
.
x1_CHAR_HEIGHT
);
...
...
@@ -132,13 +134,22 @@ class MinimapLayout {
this
.
startLineNumber
=
1
;
this
.
endLineNumber
=
lineCount
;
}
else
{
const
viewportLinesFitting
=
Math
.
floor
(
viewportHeight
/
lineHeight
);
const
minimapScrollRatio
=
Math
.
min
(
1
,
(
viewportStartLineNumber
-
1
)
/
(
lineCount
-
viewportLinesFitting
));
const
minimapStartLineNumber
=
Math
.
floor
(
1
+
minimapScrollRatio
*
(
lineCount
-
minimapLinesFitting
));
const
viewportLineCount
=
(
viewportEndLineNumber
-
viewportStartLineNumber
+
1
);
// scrollbarSliderCenter = (viewportStartLineNumber - this.startLineNumber + viewportLineCount/2) * minimapLineHeight / pixelRatio;
// scrollbarSliderCenter = (viewportStartLineNumber - this.startLineNumber + viewportLineCount/2) * minimapLineHeight / pixelRatio;
// scrollbarSliderCenter * pixelRatio / minimapLineHeight = viewportStartLineNumber - this.startLineNumber + viewportLineCount/2
// this.startLineNumber = viewportStartLineNumber + viewportLineCount/2 - scrollbarSliderCenter * pixelRatio / minimapLineHeight
let
desiredStartLineNumber
=
Math
.
floor
(
viewportStartLineNumber
+
viewportLineCount
/
2
-
scrollbarSliderCenter
*
pixelRatio
/
minimapLineHeight
);
if
(
viewportStartLineNumber
<
desiredStartLineNumber
)
{
desiredStartLineNumber
=
viewportStartLineNumber
;
}
if
(
desiredStartLineNumber
+
minimapLinesFitting
-
1
>
lineCount
)
{
desiredStartLineNumber
=
lineCount
-
minimapLinesFitting
+
1
;
}
this
.
startLineNumber
=
minimap
StartLineNumber
;
this
.
endLineNumber
=
minimap
StartLineNumber
+
minimapLinesFitting
-
1
;
this
.
startLineNumber
=
desired
StartLineNumber
;
this
.
endLineNumber
=
desired
StartLineNumber
+
minimapLinesFitting
-
1
;
}
this
.
sliderTop
=
Math
.
floor
((
viewportStartLineNumber
-
this
.
startLineNumber
)
*
minimapLineHeight
/
pixelRatio
);
...
...
@@ -149,6 +160,7 @@ class MinimapLayout {
export
class
Minimap
extends
ViewPart
{
private
readonly
_viewLayout
:
IViewLayout
;
private
readonly
_editorScrollbar
:
EditorScrollbar
;
private
readonly
_domNode
:
FastDomNode
<
HTMLElement
>
;
private
readonly
_canvas
:
FastDomNode
<
HTMLCanvasElement
>
;
...
...
@@ -159,9 +171,10 @@ export class Minimap extends ViewPart {
private
_options
:
MinimapOptions
;
private
_backgroundFillData
:
Uint8ClampedArray
;
constructor
(
context
:
ViewContext
,
viewLayout
:
IViewLayout
)
{
constructor
(
context
:
ViewContext
,
viewLayout
:
IViewLayout
,
editorScrollbar
:
EditorScrollbar
)
{
super
(
context
);
this
.
_viewLayout
=
viewLayout
;
this
.
_editorScrollbar
=
editorScrollbar
;
this
.
_options
=
new
MinimapOptions
(
this
.
_context
.
configuration
);
this
.
_backgroundFillData
=
null
;
...
...
@@ -287,7 +300,8 @@ export class Minimap extends ViewPart {
renderingCtx
.
viewportHeight
,
renderingCtx
.
visibleRange
.
startLineNumber
,
renderingCtx
.
visibleRange
.
endLineNumber
,
this
.
_context
.
model
.
getLineCount
()
this
.
_context
.
model
.
getLineCount
(),
this
.
_editorScrollbar
.
getVerticalSliderVerticalCenter
()
);
this
.
_slider
.
setTop
(
layout
.
sliderTop
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录