Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xxadev
vscode
提交
240b4857
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,发现更多精彩内容 >>
提交
240b4857
编写于
4月 27, 2018
作者:
J
Joao Moreno
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
remove experiment
上级
29bead35
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
0 addition
and
208 deletion
+0
-208
src/vs/base/browser/ui/splitview/grid.ts
src/vs/base/browser/ui/splitview/grid.ts
+0
-149
test/grid.html
test/grid.html
+0
-59
未找到文件。
src/vs/base/browser/ui/splitview/grid.ts
已删除
100644 → 0
浏览文件 @
29bead35
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
'
use strict
'
;
import
{
Event
,
anyEvent
}
from
'
vs/base/common/event
'
;
import
{
Orientation
}
from
'
vs/base/browser/ui/sash/sash
'
;
import
{
append
,
$
}
from
'
vs/base/browser/dom
'
;
import
{
SplitView
,
IView
}
from
'
vs/base/browser/ui/splitview/splitview
'
;
export
{
Orientation
}
from
'
vs/base/browser/ui/sash/sash
'
;
export
class
GridNode
implements
IView
{
get
minimumSize
():
number
{
let
result
=
0
;
for
(
const
child
of
this
.
children
)
{
for
(
const
grandchild
of
child
.
children
)
{
result
+=
grandchild
.
minimumSize
;
}
}
return
result
===
0
?
50
:
result
;
}
readonly
maximumSize
=
Number
.
MAX_VALUE
;
private
_onDidChange
:
Event
<
number
|
undefined
>
=
Event
.
None
;
get
onDidChange
():
Event
<
number
|
undefined
>
{
return
this
.
_onDidChange
;
}
protected
orientation
:
Orientation
|
undefined
;
protected
size
:
number
|
undefined
;
protected
orthogonalSize
:
number
|
undefined
;
private
splitview
:
SplitView
|
undefined
;
private
children
:
GridNode
[]
=
[];
private
color
:
string
|
undefined
;
constructor
(
private
parent
?:
GridNode
,
orthogonalSize
?:
number
,
color
?:
string
)
{
this
.
orthogonalSize
=
orthogonalSize
;
this
.
color
=
color
||
`hsl(
${
Math
.
round
(
Math
.
random
()
*
360
)}
, 72%, 72%)`
;
}
render
(
container
:
HTMLElement
):
void
{
container
=
append
(
container
,
$
(
'
.node
'
));
container
.
style
.
backgroundColor
=
this
.
color
;
append
(
container
,
$
(
'
.action
'
,
{
onclick
:
()
=>
this
.
split
(
container
,
Orientation
.
HORIZONTAL
)
},
'
⬌
'
));
append
(
container
,
$
(
'
.action
'
,
{
onclick
:
()
=>
this
.
split
(
container
,
Orientation
.
VERTICAL
)
},
'
⬍
'
));
}
protected
split
(
container
:
HTMLElement
,
orientation
:
Orientation
):
void
{
if
(
this
.
parent
&&
this
.
parent
.
orientation
===
orientation
)
{
const
index
=
this
.
parent
.
children
.
indexOf
(
this
);
this
.
parent
.
addChild
(
this
.
size
/
2
,
this
.
orthogonalSize
,
index
+
1
);
}
else
{
this
.
branch
(
container
,
orientation
);
}
}
protected
branch
(
container
:
HTMLElement
,
orientation
:
Orientation
):
void
{
this
.
orientation
=
orientation
;
container
.
innerHTML
=
''
;
this
.
splitview
=
new
SplitView
(
container
,
{
orientation
});
this
.
layout
(
this
.
size
);
this
.
orthogonalLayout
(
this
.
orthogonalSize
);
this
.
addChild
(
this
.
orthogonalSize
/
2
,
this
.
size
,
0
,
this
.
color
);
this
.
addChild
(
this
.
orthogonalSize
/
2
,
this
.
size
);
}
layout
(
size
:
number
):
void
{
this
.
size
=
size
;
for
(
const
child
of
this
.
children
)
{
child
.
orthogonalLayout
(
size
);
}
}
orthogonalLayout
(
size
:
number
):
void
{
this
.
orthogonalSize
=
size
;
if
(
this
.
splitview
)
{
this
.
splitview
.
layout
(
size
);
}
}
private
addChild
(
size
:
number
,
orthogonalSize
:
number
,
index
?:
number
,
color
?:
string
):
void
{
const
child
=
new
GridNode
(
this
,
orthogonalSize
,
color
);
this
.
splitview
.
addView
(
child
,
size
,
index
);
if
(
typeof
index
===
'
number
'
)
{
this
.
children
.
splice
(
index
,
0
,
child
);
}
else
{
this
.
children
.
push
(
child
);
}
this
.
_onDidChange
=
anyEvent
(...
this
.
children
.
map
(
c
=>
c
.
onDidChange
));
}
}
export
class
RootGridNode
extends
GridNode
{
private
width
:
number
;
private
height
:
number
;
protected
branch
(
container
:
HTMLElement
,
orientation
:
Orientation
):
void
{
if
(
orientation
===
Orientation
.
VERTICAL
)
{
this
.
size
=
this
.
width
;
this
.
orthogonalSize
=
this
.
height
;
}
else
{
this
.
size
=
this
.
height
;
this
.
orthogonalSize
=
this
.
width
;
}
super
.
branch
(
container
,
orientation
);
}
layoutBox
(
width
:
number
,
height
:
number
):
void
{
if
(
this
.
orientation
===
Orientation
.
VERTICAL
)
{
this
.
layout
(
width
);
this
.
orthogonalLayout
(
height
);
}
else
if
(
this
.
orientation
===
Orientation
.
HORIZONTAL
)
{
this
.
layout
(
height
);
this
.
orthogonalLayout
(
width
);
}
else
{
this
.
width
=
width
;
this
.
height
=
height
;
}
}
}
export
class
Grid
{
private
root
:
RootGridNode
;
constructor
(
container
:
HTMLElement
)
{
this
.
root
=
new
RootGridNode
();
this
.
root
.
render
(
container
);
}
layout
(
width
:
number
,
height
:
number
):
void
{
this
.
root
.
layoutBox
(
width
,
height
);
}
}
test/grid.html
已删除
100644 → 0
浏览文件 @
29bead35
<!DOCTYPE html>
<html>
<head>
<meta
charset=
"utf-8"
/>
<meta
http-equiv=
"X-UA-Compatible"
content=
"IE=edge"
>
<title>
Grid Example
</title>
<meta
name=
"viewport"
content=
"width=device-width, initial-scale=1"
>
<script
src=
"../out/vs/loader.js"
></script>
<script>
require
.
config
({
baseUrl
:
'
../out
'
});
require
([
'
vs/base/browser/ui/splitview/grid
'
],
({
Grid
})
=>
{
const
grid
=
new
Grid
(
document
.
body
);
const
layout
=
()
=>
grid
.
layout
(
document
.
body
.
clientWidth
,
document
.
body
.
clientHeight
);
window
.
onresize
=
layout
;
layout
();
});
</script>
<style>
html
,
body
{
width
:
100%
;
height
:
100%
;
padding
:
0
;
margin
:
0
;
}
.node
{
width
:
100%
;
height
:
100%
;
box-sizing
:
border-box
;
display
:
flex
;
align-items
:
center
;
justify-content
:
center
;
}
.action
{
display
:
inline-block
;
width
:
16px
;
height
:
16px
;
border
:
1px
solid
#3c3c3c
;
text-align
:
center
;
line-height
:
16px
;
border-radius
:
3px
;
}
.action
:hover
{
cursor
:
pointer
;
background-color
:
#ffffff54
;
}
</style>
</head>
<body>
</body>
</html>
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录