1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
/*
* Copyright 1997-2008 Sun Microsystems, Inc. All Rights Reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Sun designates this
* particular file as subject to the "Classpath" exception as provided
* by Sun in the LICENSE file that accompanied this code.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
* CA 95054 USA or visit www.sun.com if you need additional information or
* have any questions.
*
*/
package javax.media.j3d;
import javax.vecmath.Point3d;
import javax.vecmath.Point4d;
/**
* PickSegment is a line segment pick shape. It can
* be used as an argument to the picking methods in BranchGroup and Locale.
*
* @see BranchGroup#pickAll
* @see Locale#pickAll
*/
public final class PickSegment extends PickShape {
Point3d start;
Point3d end;
/**
* Constructs an empty PickSegment.
* The start and end points of the line segment are
* initialized to (0,0,0).
*/
public PickSegment() {
this.start = new Point3d();
this.end = new Point3d();
}
/**
* Constructs a line segment pick shape from the specified
* parameters.
* @param start the start point of the line segment.
* @param end the end point of the line segment.
*/
public PickSegment(Point3d start, Point3d end) {
this.start = new Point3d(start);
this.end = new Point3d(end);
}
/**
* Sets the parameters of this PickSegment to the specified values.
* @param start the start point of the line segment.
* @param end the end point of the line segment.
*/
public void set(Point3d start, Point3d end) {
this.start.x = start.x;
this.start.y = start.y;
this.start.z = start.z;
this.end.x = end.x;
this.end.y = end.y;
this.end.z = end.z;
}
/**
* Gets the parameters from this PickSegment.
* @param start the Point3d object into which the start
* point will be copied.
* @param end the Point3d object into which the end point
* will be copied.
*/
public void get(Point3d start, Point3d end) {
start.x = this.start.x;
start.y = this.start.y;
start.z = this.start.z;
end.x = this.end.x;
end.y = this.end.y;
end.z = this.end.z;
}
/**
* Return true if shape intersect with bounds.
* The point of intersection is stored in pickPos.
*/
@Override
final boolean intersect(Bounds bounds, Point4d pickPos) {
return bounds.intersect(start, end, pickPos);
}
// Only use within J3D.
// Return a new PickSegment that is the transformed (t3d) of this pickSegment.
@Override
PickShape transform(Transform3D t3d) {
PickSegment newPS = new PickSegment(start, end);
t3d.transform(newPS.start);
t3d.transform(newPS.end);
return newPS;
}
@Override
Point3d getStartPoint() {
return start;
}
@Override
int getPickType() {
return PICKSEGMENT;
}
}
|