halfspace.as

来自「flex3d 的源码」· AS 代码 · 共 39 行

AS
39
字号
package engine.geom
{

    public class HalfSpace
    {

		public var normal:Point3D ; // normal to boundary plane/
		public var d:Number; // eqn of half space is normal.x - d > 0
		  
		  /*
		  /** Create a half space
		  public HalfSpace(Point3d a,Point3d b,Point3d c){
		normal = b.subtract(a).cross(c.subtract(a)).normalize();
		d = normal.dot(a);
		  }
		*/
		
		/** Create a half space parallel to z axis
		*/
		public function HalfSpace( a:Point3D, b:Point3D )
		{
			normal = b.subtract(a).cross(new Point3D(0,0,1)).normalize();
			d = normal.dot(a);
		}
		
		public function inside ( p:Point3D ) : Boolean
		{
			return normal.dot(p) > d;
		}
		
		/** z coordinate of intersection of a vertical line through p and boundary plane */
		//public function zint( p:Point3D ) : Number
		//{
			//return (d - normal.x()*p.x() - normal.y()*p.y()) / normal.z();
		//}

    }
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?