Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
10237b64
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,体验更适合开发者的 AI 搜索 >>
提交
10237b64
编写于
9月 21, 2017
作者:
B
Benjamin Pasero
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
touch bar: reuse entries to avoid flickering
上级
b86108e5
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
65 addition
and
31 deletion
+65
-31
src/vs/code/electron-main/window.ts
src/vs/code/electron-main/window.ts
+65
-31
未找到文件。
src/vs/code/electron-main/window.ts
浏览文件 @
10237b64
...
...
@@ -94,6 +94,8 @@ export class CodeWindow implements ICodeWindow {
private
currentConfig
:
IWindowConfiguration
;
private
pendingLoadConfig
:
IWindowConfiguration
;
private
touchBarGroups
:
Map
<
string
,
Electron
.
TouchBarSegmentedControl
>
;
constructor
(
config
:
IWindowCreationOptions
,
@
ILogService
private
logService
:
ILogService
,
...
...
@@ -103,6 +105,7 @@ export class CodeWindow implements ICodeWindow {
@
IWorkspacesMainService
private
workspaceService
:
IWorkspacesMainService
,
@
IBackupMainService
private
backupService
:
IBackupMainService
)
{
this
.
touchBarGroups
=
new
Map
<
string
,
Electron
.
TouchBarSegmentedControl
>
();
this
.
_lastFocusTime
=
-
1
;
this
.
_readyState
=
ReadyState
.
NONE
;
this
.
whenReadyCallbacks
=
[];
...
...
@@ -858,49 +861,80 @@ export class CodeWindow implements ICodeWindow {
this
.
_win
.
webContents
.
send
(
channel
,
...
args
);
}
public
updateTouchBar
(
item
s
:
ICommandAction
[][]):
void
{
public
updateTouchBar
(
group
s
:
ICommandAction
[][]):
void
{
if
(
!
isMacintosh
)
{
return
;
// only supported on macOS
}
const
groups
:
(
Electron
.
TouchBarGroup
|
Electron
.
TouchBarSpacer
)[]
=
[];
// Clean up previous groups no longer in use
const
groupHashes
:
string
[]
=
[];
groups
.
forEach
(
group
=>
groupHashes
.
push
(
this
.
getTouchBarGroupHash
(
group
)));
this
.
touchBarGroups
.
forEach
((
value
,
key
)
=>
{
if
(
groupHashes
.
indexOf
(
key
)
===
-
1
)
{
this
.
touchBarGroups
.
delete
(
key
);
}
});
items
.
forEach
(
itemGroup
=>
{
if
(
itemGroup
.
length
)
{
// Build touchbar from groups
const
touchBarGroups
:
(
Electron
.
TouchBarGroup
|
Electron
.
TouchBarSpacer
)[]
=
[];
groups
.
forEach
(
group
=>
{
if
(
group
.
length
)
{
const
groupHash
=
this
.
getTouchBarGroupHash
(
group
);
// To avoid flickering, we try to reuse the touch bar group
// as much as possible by checking for a previously created
// group that has the same number of items with same style.
let
groupTouchBar
:
Electron
.
TouchBarSegmentedControl
;
if
(
this
.
touchBarGroups
.
has
(
groupHash
))
{
groupTouchBar
=
this
.
touchBarGroups
.
get
(
groupHash
);
}
else
{
groupTouchBar
=
this
.
createTouchBarGroup
(
group
);
this
.
touchBarGroups
.
set
(
groupHash
,
groupTouchBar
);
}
// Group Segments
const
groupSegments
=
itemGroup
.
map
(
item
=>
{
let
icon
:
Electron
.
NativeImage
;
if
(
item
.
iconPath
)
{
icon
=
nativeImage
.
createFromPath
(
item
.
iconPath
);
if
(
icon
.
isEmpty
())
{
icon
=
void
0
;
}
}
// Push and add small space between groups
touchBarGroups
.
push
(
groupTouchBar
);
touchBarGroups
.
push
(
new
TouchBar
.
TouchBarSpacer
({
size
:
'
small
'
}));
}
});
return
{
label
:
!
icon
?
item
.
title
as
string
:
void
0
,
icon
};
});
this
.
_win
.
setTouchBar
(
new
TouchBar
({
items
:
touchBarGroups
}));
}
// Group Touch Bar
const
groupTouchBar
=
new
TouchBar
.
TouchBarSegmentedControl
({
segments
:
groupSegments
,
mode
:
'
buttons
'
,
segmentStyle
:
'
automatic
'
,
change
:
(
selectedIndex
)
=>
{
this
.
sendWhenReady
(
'
vscode:runAction
'
,
itemGroup
[
selectedIndex
].
id
);
}
});
private
getTouchBarGroupHash
(
items
:
ICommandAction
[]):
string
{
let
id
=
''
;
items
.
forEach
(
item
=>
id
+=
(
item
.
id
+
item
.
title
+
item
.
iconPath
));
// Push and add small space between groups
groups
.
push
(
groupTouchBar
);
groups
.
push
(
new
TouchBar
.
TouchBarSpacer
({
size
:
'
small
'
}));
return
id
;
}
private
createTouchBarGroup
(
items
:
ICommandAction
[]):
Electron
.
TouchBarSegmentedControl
{
// Group Segments
const
segments
=
items
.
map
(
item
=>
{
let
icon
:
Electron
.
NativeImage
;
if
(
item
.
iconPath
)
{
icon
=
nativeImage
.
createFromPath
(
item
.
iconPath
);
if
(
icon
.
isEmpty
())
{
icon
=
void
0
;
}
}
return
{
label
:
!
icon
?
item
.
title
as
string
:
void
0
,
icon
};
});
this
.
_win
.
setTouchBar
(
new
TouchBar
({
items
:
groups
}));
// Group Touch Bar
return
new
TouchBar
.
TouchBarSegmentedControl
({
segments
,
mode
:
'
buttons
'
,
segmentStyle
:
'
automatic
'
,
change
:
(
selectedIndex
)
=>
{
this
.
sendWhenReady
(
'
vscode:runAction
'
,
items
[
selectedIndex
].
id
);
}
});
}
public
dispose
():
void
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录