本文整理汇总了C#中Ray.GetPointOnRay方法的典型用法代码示例。如果您正苦于以下问题:C# Ray.GetPointOnRay方法的具体用法?C# Ray.GetPointOnRay怎么用?C# Ray.GetPointOnRay使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Ray
的用法示例。
在下文中一共展示了Ray.GetPointOnRay方法的6个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: OnGetEditorSelectionByRay
protected override bool OnGetEditorSelectionByRay( Ray ray, out Vec3 pos, ref float priority )
{
float scale1, scale2;
bool ret = GetBox().RayIntersection( ray, out scale1, out scale2 );
if( ret )
pos = ray.GetPointOnRay( Math.Min( scale1, scale2 ) );
else
pos = Vec3.Zero;
return ret;
}
示例2: GetDirectionalLightCameraDestinationPoint
Vec3 GetDirectionalLightCameraDestinationPoint( Camera mainCamera, Vec3[] cornerPoints )
{
if( mainCamera.ProjectionType == ProjectionTypes.Perspective )
{
//perspective camera
Ray cameraDirectionAsRay = new Ray( mainCamera.DerivedPosition, mainCamera.DerivedDirection );
Vec3 nearPoint = cornerPoints[ 0 ];
Vec3 farPoint = cornerPoints[ 4 ];
Vec3 projectedPoint = MathUtils.ProjectPointToLine( cameraDirectionAsRay.Origin,
cameraDirectionAsRay.Origin + cameraDirectionAsRay.Direction, farPoint );
if( ( projectedPoint - farPoint ).Length() >= ( projectedPoint - nearPoint ).Length() )
{
return projectedPoint;
}
else
{
Vec3 centerBetweenPoints = ( nearPoint + farPoint ) / 2;
Vec3 normal = ( farPoint - centerBetweenPoints ).GetNormalize();
Plane plane = Plane.FromPointAndNormal( centerBetweenPoints, normal );
float scale;
plane.RayIntersection( cameraDirectionAsRay, out scale );
return cameraDirectionAsRay.GetPointOnRay( scale );
}
}
else
{
//orthographic camera
Vec3 destinationPoint = Vec3.Zero;
foreach( Vec3 point in cornerPoints )
destinationPoint += point;
destinationPoint /= (float)cornerPoints.Length;
return destinationPoint;
}
}
示例3: GetDirectionalLightCameraCornerPoints
void GetDirectionalLightCameraCornerPoints( Camera mainCamera, float initialNearDistance,
float initialFarDistance, bool clipByShadowFarDistance, out Vec3[] cornerPoints )
{
float nearDistance = initialNearDistance;
float farDistance = initialFarDistance;
Frustum frustum = FrustumUtils.GetFrustumByCamera( mainCamera );
//clip by shadow far distance sphere (only for perspective camera)
if( mainCamera.ProjectionType == ProjectionTypes.Perspective && clipByShadowFarDistance )
{
Vec3[] points = null;
frustum.ToPoints( ref points );
Sphere sphere = new Sphere( mainCamera.DerivedPosition, farDistance );
Vec3[] intersections = new Vec3[ 3 ];
for( int n = 0; n < 3; n++ )
{
Vec3 pointEnd = points[ n + 4 ];
float scale1;
float scale2;
Ray ray = new Ray( mainCamera.DerivedPosition, pointEnd - mainCamera.DerivedPosition );
sphere.RayIntersection( ray, out scale1, out scale2 );
float scale = Math.Max( scale1, scale2 );
intersections[ n ] = ray.GetPointOnRay( scale );
}
Plane farPlane = Plane.FromPoints( intersections[ 0 ], intersections[ 1 ], intersections[ 2 ] );
Ray cameraDirectionAsRay = new Ray( mainCamera.DerivedPosition, mainCamera.DerivedDirection );
Vec3 pointByDirection;
farPlane.RayIntersection( cameraDirectionAsRay, out pointByDirection );
farDistance = ( pointByDirection - mainCamera.DerivedPosition ).Length();
if( nearDistance + 5 > farDistance )
farDistance = nearDistance + 5;
}
if( nearDistance < .0001f )
nearDistance = .0001f;
if( farDistance < nearDistance + .01f )
farDistance = nearDistance + .01f;
frustum.NearDistance = nearDistance;
frustum.MoveFarDistance( farDistance );
cornerPoints = null;
frustum.ToPoints( ref cornerPoints );
}
示例4: CreateWaterPlaneSplash
private void CreateWaterPlaneSplash(Ray ray)
{
if (ray.Direction.Z >= 0)
return;
foreach (WaterPlane waterPlane in WaterPlane.Instances)
{
//check by plane
Plane plane = new Plane(Vec3.ZAxis, waterPlane.Position.Z);
float scale;
if (!plane.LineIntersection(ray.Origin, ray.Origin + ray.Direction, out scale))
continue;
Vec3 pos = ray.GetPointOnRay(scale);
//check by bounds
Rect bounds2 = new Rect(waterPlane.Position.ToVec2());
bounds2.Expand(waterPlane.Size * .5f);
if (!bounds2.IsContainsPoint(pos.ToVec2()))
continue;
//create splash
waterPlane.CreateSplash(WaterPlaneType.SplashTypes.Bullet, pos);
}
}
示例5: MakeConvexPolyhedronForSpotLight
static ConvexPolyhedron MakeConvexPolyhedronForSpotLight( RenderLight light )
{
float outerAngle = light.SpotlightOuterAngle;
if( outerAngle < new Degree( 1 ).InRadians() )
outerAngle = new Degree( 1 ).InRadians();
if( outerAngle > new Degree( 179 ).InRadians() )
outerAngle = new Degree( 179 ).InRadians();
List<Vec3> vertices = new List<Vec3>( 10 );
List<ConvexPolyhedron.Face> faces = new List<ConvexPolyhedron.Face>( 16 );
Mat3 worldRotation = Quat.FromDirectionZAxisUp( light.Direction ).ToMat3();
float sideAngle;
{
float radius = MathFunctions.Sin( outerAngle / 2 ) * light.AttenuationFar;
float l = MathFunctions.Sqrt( light.AttenuationFar * light.AttenuationFar - radius * radius );
radius /= MathFunctions.Cos( MathFunctions.PI * 2 / 16 );
sideAngle = MathFunctions.ATan( radius / l );
}
Vec3 farPoint;
{
Mat3 pointRotation = worldRotation * Mat3.FromRotateByY( outerAngle / 4 );
Vec3 direction = pointRotation * Vec3.XAxis;
Vec3 point = light.Position + direction * light.AttenuationFar;
Plane plane = Plane.FromPointAndNormal( point, direction );
Ray ray = new Ray( light.Position, light.Direction * light.AttenuationFar );
float scale;
plane.RayIntersection( ray, out scale );
farPoint = ray.GetPointOnRay( scale * 1.05f );
}
vertices.Add( light.Position );
vertices.Add( farPoint );
for( int nAxisAngle = 0; nAxisAngle < 8; nAxisAngle++ )
{
float axisAngle = ( MathFunctions.PI * 2 ) * ( (float)nAxisAngle / 8 );
Mat3 worldAxisRotation = worldRotation * Mat3.FromRotateByX( axisAngle );
Plane sidePlane;
{
Mat3 sideAngleRotation = Mat3.FromRotateByY( sideAngle + MathFunctions.PI / 2 );
Mat3 pointRotation = worldAxisRotation * sideAngleRotation;
sidePlane = Plane.FromPointAndNormal( light.Position, pointRotation * Vec3.XAxis );
}
{
Mat3 pointRotation = worldAxisRotation * Mat3.FromRotateByY( outerAngle / 4 );
Vec3 direction = pointRotation * Vec3.XAxis;
Vec3 point = light.Position + direction * ( light.AttenuationFar * 1.05f );
Ray ray = new Ray( farPoint, point - farPoint );
float scale;
sidePlane.RayIntersection( ray, out scale );
Vec3 p = ray.GetPointOnRay( scale );
vertices.Add( p );
}
}
for( int n = 0; n < 8; n++ )
{
faces.Add( new ConvexPolyhedron.Face( 0, n + 2, ( n + 1 ) % 8 + 2 ) );
faces.Add( new ConvexPolyhedron.Face( 1, ( n + 1 ) % 8 + 2, n + 2 ) );
}
//foreach( ConvexPolyhedron.Face face in faces )
//{
// camera.DebugGeometry.Color = new ColorValue( 0, 0, 1 );
// Vec3 p0 = vertices[ face.Vertex0 ];
// Vec3 p1 = vertices[ face.Vertex1 ];
// Vec3 p2 = vertices[ face.Vertex2 ];
// camera.DebugGeometry.AddLine( p0, p1 );
// camera.DebugGeometry.AddLine( p1, p2 );
// camera.DebugGeometry.AddLine( p2, p0 );
// Vec3[] v = new Vec3[ 3 ] { p0, p1, p2 };
// int[] i = new int[] { 0, 1, 2 };
// camera.DebugGeometry.Color = new ColorValue( 0, 0, 1, .5f );
// camera.DebugGeometry.AddVertexIndexBuffer( v, i, Mat4.Identity, false, true );
//}
//camera.DebugGeometry.Color = new ColorValue( 1, 0, 0 );
//foreach( Vec3 vertex in vertices )
// camera.DebugGeometry.AddSphere( new Sphere( vertex, .1f ) );
return new ConvexPolyhedron( vertices.ToArray(), faces.ToArray(), .0001f );
}
示例6: GetClipPlanesForDirectionalLightShadowGeneration
static Plane[] GetClipPlanesForDirectionalLightShadowGeneration( Camera camera,
RenderLight light, float farClipDistance)
{
float shadowFarDistance = SceneManager.Instance.ShadowFarDistance;
Frustum cameraFrustum = FrustumUtils.GetFrustumByCamera( camera, farClipDistance );
Vec3 cameraPosition = cameraFrustum.Origin;
Vec3 farCenterPoint;
{
float distance = shadowFarDistance;
//small border
distance *= 1.05f;
//not optimal
distance *= MathFunctions.Sqrt( 2 );
farCenterPoint = cameraPosition + cameraFrustum.Axis.Item0 * distance;
}
Vec3 pyramidCenter = ( cameraPosition + farCenterPoint ) * .5f;
Plane farPlane;
{
Vec3 normal = ( farCenterPoint - cameraPosition ).GetNormalize();
float distance = Vec3.Dot( normal, farCenterPoint );
farPlane = new Plane( normal, distance );
}
Vec3[] farCorners = new Vec3[ 4 ];
{
//4 - top-right far, 5 - top-left far, 6 - bottom-left far, 7 - bottom-right far.
Vec3[] points = camera.GetWorldSpaceCorners();
for( int n = 0; n < 4; n++ )
{
Ray ray = new Ray( cameraPosition, points[ n + 4 ] - cameraPosition );
float scale;
farPlane.RayIntersection( ray, out scale );
farCorners[ n ] = ray.GetPointOnRay( scale );
}
}
Vec3[] pyramidPoints = new Vec3[ 5 ];
{
pyramidPoints[ 0 ] = cameraPosition;
for( int n = 0; n < 4; n++ )
pyramidPoints[ n + 1 ] = farCorners[ n ];
}
Line[] pyramidEdges = new Line[ 8 ];
{
for( int n = 0; n < 4; n++ )
{
pyramidEdges[ n ] = new Line( cameraPosition, farCorners[ n ] );
pyramidEdges[ n + 4 ] = new Line( farCorners[ n ],
farCorners[ ( n + 1 ) % 4 ] );
}
}
List<Plane> clipPlanes = new List<Plane>( 7 );
{
Vec3 lightDirectionOffset = light.Direction * 10000.0f;
//back planes
{
if( farPlane.GetSide( farCenterPoint - lightDirectionOffset ) ==
Plane.Side.Negative )
{
clipPlanes.Add( farPlane );
}
for( int n = 0; n < 4; n++ )
{
Plane plane = Plane.FromPoints( cameraPosition, farCorners[ n ],
farCorners[ ( n + 1 ) % 4 ] );
if( plane.GetSide( cameraPosition - lightDirectionOffset ) ==
Plane.Side.Negative )
{
clipPlanes.Add( farPlane );
}
}
}
//generate edge planes
foreach( Line pyramidEdge in pyramidEdges )
{
Vec3 p1 = pyramidEdge.Start;
Vec3 p2 = pyramidEdge.End;
Vec3 p3 = p1 - lightDirectionOffset;
Plane plane;
{
plane = Plane.FromPoints( p1, p2, p3 );
if( plane.GetSide( pyramidCenter ) == Plane.Side.Positive )
plane = Plane.FromPoints( p2, p1, p3 );
}
bool existsPyramidPointsOnBothSides = false;
//.........这里部分代码省略.........