Merge branch 'features/r2_11_2/JAL-3821_reinstate_patch' into develop
[jalview.git] / unused / javajs / util / P4.java
1 /*
2    Copyright (C) 1997,1998,1999
3    Kenji Hiranabe, Eiwa System Management, Inc.
4
5    This program is free software.
6    Implemented by Kenji Hiranabe(hiranabe@esm.co.jp),
7    conforming to the Java(TM) 3D API specification by Sun Microsystems.
8
9    Permission to use, copy, modify, distribute and sell this software
10    and its documentation for any purpose is hereby granted without fee,
11    provided that the above copyright notice appear in all copies and
12    that both that copyright notice and this permission notice appear
13    in supporting documentation. Kenji Hiranabe and Eiwa System Management,Inc.
14    makes no representations about the suitability of this software for any
15    purpose.  It is provided "AS IS" with NO WARRANTY.
16 */
17 package javajs.util;
18
19
20
21 /**
22  * A 4 element point that is represented by single precision floating point
23  * x,y,z,w coordinates.
24  * 
25  * @version specification 1.1, implementation $Revision: 1.9 $, $Date:
26  *          2006/07/28 17:01:32 $
27  * @author Kenji hiranabe
28  * 
29  * additions by Bob Hanson hansonr@stolaf.edu 9/30/2012
30  * for unique constructor and method names
31  * for the optimization of compiled JavaScript using Java2Script
32  */
33 public class P4 extends T4 {
34
35   public P4() {
36     // skip T4() constructor
37   }
38   
39   public static P4 new4(float x, float y, float z, float w) {
40     P4 pt = new P4();
41     pt.set4(x, y, z, w);
42     return pt;
43   }
44
45   public static P4 newPt(P4 value) {
46     P4 pt = new P4();
47     pt.set4(value.x, value.y, value.z, value.w);    
48     return pt;
49   }
50
51   /**
52    * Returns the distance between this point and point p1.
53    * 
54    * @param p1
55    *        the other point
56    * @return the distance between these two points
57    */
58   public final float distance4(P4 p1) {
59     double dx = x - p1.x;
60     double dy = y - p1.y;
61     double dz = z - p1.z;
62     double dw = w - p1.w;
63     return (float) Math.sqrt(dx * dx + dy * dy + dz * dz + dw * dw);
64   }
65
66 }