Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
车家大少爷
three.js
提交
86f7b443
T
three.js
项目概览
车家大少爷
/
three.js
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
three.js
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
86f7b443
编写于
4月 29, 2013
作者:
M
Mr.doob
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
TransformControls: Dispatch change event only when really changed.
上级
fd97c09c
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
87 addition
and
80 deletion
+87
-80
examples/js/controls/TransformControls.js
examples/js/controls/TransformControls.js
+87
-80
未找到文件。
examples/js/controls/TransformControls.js
浏览文件 @
86f7b443
...
...
@@ -72,9 +72,6 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
var
intersectionPlanes
=
{};
var
intersectionPlaneList
=
[
'
XY
'
,
'
YZ
'
,
'
XZ
'
,
'
XYZE
'
];
// E
var
currentPlane
=
'
XY
'
;
var
intersect
,
planeIntersect
;
var
object
,
name
;
// intersection planes
{
...
...
@@ -115,45 +112,41 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
this
.
gizmo
.
add
(
pickerAxes
[
"
rotate
"
]
);
this
.
gizmo
.
add
(
pickerAxes
[
"
scale
"
]
);
var
HandleMaterial
=
function
(
color
)
{
var
HandleMaterial
=
function
(
color
,
opacity
)
{
var
material
=
new
THREE
.
MeshBasicMaterial
();
material
.
color
=
color
;
material
.
side
=
THREE
.
DoubleSide
;
material
.
transparent
=
true
;
material
.
depthTest
=
false
;
material
.
depthWrite
=
false
;
material
.
color
.
setRGB
(
color
[
0
],
color
[
1
],
color
[
2
]
)
;
material
.
opacity
=
color
[
3
]
;
material
.
opacity
=
opacity
!==
undefined
?
opacity
:
1
;
material
.
transparent
=
true
;
return
material
;
}
var
LineMaterial
=
function
(
color
)
{
var
LineMaterial
=
function
(
color
,
opacity
)
{
var
material
=
new
THREE
.
LineBasicMaterial
();
material
.
transparent
=
true
;
material
.
color
=
color
;
material
.
depthTest
=
false
;
material
.
depthWrite
=
false
;
material
.
color
.
setRGB
(
color
[
0
],
color
[
1
],
color
[
2
]
)
;
material
.
opacity
=
color
[
3
]
;
material
.
opacity
=
opacity
!==
undefined
?
opacity
:
1
;
material
.
transparent
=
true
;
return
material
;
}
// materials by color
var
white
=
[
1
,
1
,
1
,
0.2
]
;
var
gray
=
[
0.5
,
0.5
,
0.5
,
1
]
;
var
red
=
[
1
,
0
,
0
,
1
]
;
var
green
=
[
0
,
1
,
0
,
1
]
;
var
blue
=
[
0
,
0
,
1
,
1
]
;
var
cyan
=
[
0
,
1
,
1
,
0.2
]
;
var
magenta
=
[
1
,
0
,
1
,
0.2
]
;
var
yellow
=
[
1
,
1
,
0
,
0.2
]
;
var
white
=
new
THREE
.
Color
(
0xffffff
)
;
var
gray
=
new
THREE
.
Color
(
0x808080
)
;
var
red
=
new
THREE
.
Color
(
0xff0000
)
;
var
green
=
new
THREE
.
Color
(
0x00ff00
)
;
var
blue
=
new
THREE
.
Color
(
0x0000ff
)
;
var
cyan
=
new
THREE
.
Color
(
0x00ffff
)
;
var
magenta
=
new
THREE
.
Color
(
0xff00ff
)
;
var
yellow
=
new
THREE
.
Color
(
0xffff00
)
;
var
geometry
,
mesh
;
// Line axes
var
redColor
=
new
THREE
.
Color
(
0xff0000
);
var
greenColor
=
new
THREE
.
Color
(
0x00ff00
);
var
blueColor
=
new
THREE
.
Color
(
0x0000ff
);
geometry
=
new
THREE
.
Geometry
();
geometry
.
vertices
.
push
(
new
THREE
.
Vector3
(
0
,
0
,
0
),
new
THREE
.
Vector3
(
1
,
0
,
0
),
...
...
@@ -161,7 +154,7 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
new
THREE
.
Vector3
(
0
,
0
,
0
),
new
THREE
.
Vector3
(
0
,
0
,
1
)
);
geometry
.
colors
.
push
(
red
Color
,
redColor
,
greenColor
,
greenColor
,
blueColor
,
blueColor
red
,
red
,
green
,
green
,
blue
,
blue
);
material
=
new
THREE
.
LineBasicMaterial
(
{
vertexColors
:
THREE
.
VertexColors
,
...
...
@@ -175,21 +168,21 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
// Translate handles
mesh
=
new
THREE
.
Mesh
(
new
THREE
.
OctahedronGeometry
(
0.1
,
0
),
HandleMaterial
(
white
)
);
mesh
=
new
THREE
.
Mesh
(
new
THREE
.
OctahedronGeometry
(
0.1
,
0
),
HandleMaterial
(
white
,
0.25
)
);
mesh
.
name
=
'
TXYZ
'
;
displayAxes
[
'
translate
'
].
add
(
mesh
);
pickerAxes
[
'
translate
'
].
add
(
mesh
.
clone
()
);
geometry
=
new
THREE
.
PlaneGeometry
(
0.3
,
0.3
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
yellow
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
yellow
,
0.25
)
);
mesh
.
position
.
set
(
0.15
,
0.15
,
0
);
bakeTransformations
(
mesh
);
mesh
.
name
=
'
TXY
'
;
displayAxes
[
'
translate
'
].
add
(
mesh
);
pickerAxes
[
'
translate
'
].
add
(
mesh
.
clone
()
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
cyan
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
cyan
,
0.25
)
);
mesh
.
position
.
set
(
0
,
0.15
,
0.15
);
mesh
.
rotation
.
y
=
Math
.
PI
/
2
;
bakeTransformations
(
mesh
);
...
...
@@ -197,7 +190,7 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
displayAxes
[
'
translate
'
].
add
(
mesh
);
pickerAxes
[
'
translate
'
].
add
(
mesh
.
clone
()
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
magenta
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
magenta
,
0.25
)
);
mesh
.
position
.
set
(
0.15
,
0
,
0.15
);
mesh
.
rotation
.
x
=
Math
.
PI
/
2
;
bakeTransformations
(
mesh
);
...
...
@@ -253,26 +246,26 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
geometry
=
new
THREE
.
CubeGeometry
(
0.125
,
0.125
,
0.125
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
white
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
white
,
0.25
)
);
mesh
.
name
=
'
SXYZ
'
;
displayAxes
[
'
scale
'
].
add
(
mesh
);
pickerAxes
[
'
scale
'
].
add
(
mesh
.
clone
()
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
[
1
,
0
,
0
,
0.25
]
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
red
)
);
mesh
.
position
.
set
(
1.05
,
0
,
0
);
bakeTransformations
(
mesh
);
mesh
.
name
=
'
SX
'
;
displayAxes
[
'
scale
'
].
add
(
mesh
);
pickerAxes
[
'
scale
'
].
add
(
mesh
.
clone
()
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
[
0
,
1
,
0
,
0.25
]
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
green
)
);
mesh
.
position
.
set
(
0
,
1.05
,
0
);
bakeTransformations
(
mesh
);
mesh
.
name
=
'
SY
'
;
displayAxes
[
'
scale
'
].
add
(
mesh
);
pickerAxes
[
'
scale
'
].
add
(
mesh
.
clone
()
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
[
0
,
0
,
1
,
0.25
]
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
blue
)
);
mesh
.
position
.
set
(
0
,
0
,
1.05
);
bakeTransformations
(
mesh
);
mesh
.
name
=
'
SZ
'
;
...
...
@@ -310,33 +303,33 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
mesh
.
name
=
'
RXYZE
'
;
displayAxes
[
'
rotate
'
].
add
(
mesh
);
mesh
=
new
THREE
.
Line
(
Circle
(
1.25
,
'
z
'
),
LineMaterial
(
[
1
,
1
,
0
,
0.25
]
)
);
mesh
=
new
THREE
.
Line
(
Circle
(
1.25
,
'
z
'
),
LineMaterial
(
yellow
,
0.25
)
);
mesh
.
name
=
'
RE
'
;
displayAxes
[
'
rotate
'
].
add
(
mesh
);
geometry
=
new
THREE
.
TorusGeometry
(
1
,
0.15
,
4
,
6
,
Math
.
PI
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
cyan
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
red
)
);
mesh
.
rotation
.
z
=
-
Math
.
PI
/
2
;
mesh
.
rotation
.
y
=
-
Math
.
PI
/
2
;
bakeTransformations
(
mesh
);
mesh
.
name
=
'
RX
'
;
pickerAxes
[
'
rotate
'
].
add
(
mesh
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
magenta
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
green
)
);
mesh
.
rotation
.
z
=
Math
.
PI
;
mesh
.
rotation
.
x
=
-
Math
.
PI
/
2
;
bakeTransformations
(
mesh
);
mesh
.
name
=
'
RY
'
;
pickerAxes
[
'
rotate
'
].
add
(
mesh
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
yellow
)
);
mesh
=
new
THREE
.
Mesh
(
geometry
,
HandleMaterial
(
blue
)
);
mesh
.
rotation
.
z
=
-
Math
.
PI
/
2
;
bakeTransformations
(
mesh
);
mesh
.
name
=
'
RZ
'
;
pickerAxes
[
'
rotate
'
].
add
(
mesh
);
mesh
=
new
THREE
.
Mesh
(
new
THREE
.
SphereGeometry
(
0.95
,
12
,
12
),
HandleMaterial
(
white
)
);
mesh
=
new
THREE
.
Mesh
(
new
THREE
.
SphereGeometry
(
0.95
,
12
,
12
),
HandleMaterial
(
white
,
0.25
)
);
mesh
.
name
=
'
RXYZE
'
;
pickerAxes
[
'
rotate
'
].
add
(
mesh
);
...
...
@@ -344,7 +337,7 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
intersectionPlanes
[
'
SPHERE
'
].
visible
=
false
;
planes
.
add
(
intersectionPlanes
[
'
SPHERE
'
]);
mesh
=
new
THREE
.
Mesh
(
new
THREE
.
TorusGeometry
(
1.30
,
0.15
,
4
,
12
),
HandleMaterial
(
yellow
)
);
mesh
=
new
THREE
.
Mesh
(
new
THREE
.
TorusGeometry
(
1.30
,
0.15
,
4
,
12
),
HandleMaterial
(
yellow
,
0.25
)
);
mesh
.
name
=
'
RE
'
;
pickerAxes
[
'
rotate
'
].
add
(
mesh
);
...
...
@@ -391,8 +384,8 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
for
(
var
j
in
this
.
gizmo
.
children
[
i
].
children
)
{
object
=
this
.
gizmo
.
children
[
i
].
children
[
j
];
name
=
object
.
name
;
var
object
=
this
.
gizmo
.
children
[
i
].
children
[
j
];
var
name
=
object
.
name
;
if
(
name
.
search
(
'
E
'
)
!=
-
1
){
...
...
@@ -586,41 +579,53 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
}
var
hovered
=
null
;
var
hoveredColor
=
new
THREE
.
Color
();
var
hoveredOpacity
=
1
;
function
onMouseHover
(
event
)
{
event
.
preventDefault
();
if
(
event
.
button
===
0
&&
!
scope
.
activ
e
)
{
if
(
event
.
button
===
0
&&
scope
.
active
===
fals
e
)
{
intersect
=
intersectObjects
(
event
,
pickerAxes
[
scope
.
mode
].
children
);
var
intersect
=
intersectObjects
(
event
,
pickerAxes
[
scope
.
mode
].
children
);
for
(
var
i
in
displayAxes
[
scope
.
mode
].
children
)
{
if
(
intersect
)
{
var
axis
=
displayAxes
[
scope
.
mode
].
children
[
i
];
if
(
hovered
!==
intersect
.
object
)
{
if
(
intersect
&&
axis
.
name
==
intersect
.
object
.
name
)
{
if
(
hovered
!==
null
)
{
axis
.
material
.
color
.
setRGB
(
1
,
1
,
0
);
axis
.
material
.
opacity
=
1
;
hovered
.
material
.
color
.
copy
(
hoveredColor
);
hovered
.
material
.
opacity
=
hoveredOpacity
;
}
else
if
(
axis
.
material
.
origColor
)
{
}
axis
.
material
.
color
.
copy
(
axis
.
material
.
origColor
);
axis
.
material
.
opacity
=
axis
.
material
.
origOpacity
;
hovered
=
intersect
.
object
;
hoveredColor
.
copy
(
hovered
.
material
.
color
);
hoveredOpacity
=
hovered
.
material
.
opacity
;
}
else
{
hovered
.
material
.
color
.
setRGB
(
1
,
1
,
0
);
hovered
.
material
.
opacity
=
1
;
axis
.
material
.
origColor
=
axis
.
material
.
color
.
clone
();
axis
.
material
.
origOpacity
=
axis
.
material
.
opacity
;
scope
.
dispatchEvent
(
changeEvent
);
}
}
}
else
if
(
hovered
!==
null
)
{
hovered
.
material
.
color
.
copy
(
hoveredColor
);
hovered
.
material
.
opacity
=
hoveredOpacity
;
hovered
=
null
;
scope
.
dispatchEvent
(
changeEvent
);
}
}
scope
.
document
.
addEventListener
(
'
mousemove
'
,
onMouseMove
,
false
);
scope
.
document
.
addEventListener
(
'
mouseup
'
,
onMouseUp
,
false
);
...
...
@@ -632,7 +637,7 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
if
(
event
.
button
===
0
)
{
intersect
=
intersectObjects
(
event
,
pickerAxes
[
scope
.
mode
].
children
);
var
intersect
=
intersectObjects
(
event
,
pickerAxes
[
scope
.
mode
].
children
);
if
(
intersect
)
{
...
...
@@ -641,7 +646,7 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
scope
.
update
();
scope
.
setIntersectionPlane
();
planeIntersect
=
intersectObjects
(
event
,
[
intersectionPlanes
[
currentPlane
]]
);
var
planeIntersect
=
intersectObjects
(
event
,
[
intersectionPlanes
[
currentPlane
]]
);
if
(
planeIntersect
)
{
...
...
@@ -671,7 +676,7 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
if
(
scope
.
active
)
{
planeIntersect
=
intersectObjects
(
event
,
[
intersectionPlanes
[
currentPlane
]]
);
var
planeIntersect
=
intersectObjects
(
event
,
[
intersectionPlanes
[
currentPlane
]]
);
if
(
planeIntersect
)
{
...
...
@@ -914,8 +919,10 @@ THREE.TransformControls = function ( camera, domElement, doc ) {
}
function
isActive
(
name
)
{
if
(
scope
.
active
.
search
(
name
)
!=
-
1
)
return
true
;
else
return
false
;
}
function
bakeTransformations
(
object
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录