当前位置: 首页>>代码示例>>C#>>正文


C# Vector3.Dot方法代码示例

本文整理汇总了C#中System.Vector3.Dot方法的典型用法代码示例。如果您正苦于以下问题:C# Vector3.Dot方法的具体用法?C# Vector3.Dot怎么用?C# Vector3.Dot使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在System.Vector3的用法示例。


在下文中一共展示了Vector3.Dot方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Check

        /// public メソッド
        ///---------------------------------------------------------------------------
        /// カプセルと三角形との衝突
        public bool Check( DemoGame.GeometryCapsule moveCap, ShapeTriangles trgShape )
        {
            Vector3 collPos = StaticDataList.getVectorZero();
            calMovePos = moveCap.EndPos;
            calBestDis = -1.0f;
            calBestId  = -1;

            float checDis = moveCap.Line.Length + moveCap.R + collCheckDis;

            if( AppDebug.CollLightFlg == false ){
            for( int i=0; i<trgShape.EntryNum; i++ ){

                float a = (calMovePos.Dot( trgShape.Triangle[i].Plane.Nor ) + trgShape.Triangle[i].Plane.D);
                if( a >= checDis || a <= -checDis ){
                    continue;
                }

                if( DemoGame.CommonCollision.CheckSphereAndTriangle( moveCap, trgShape.Triangle[i], ref collPos ) == true ){
                    float dis = Common.VectorUtil.Distance( collPos, moveCap.StartPos );
                    if( dis < calBestDis || calBestId < 0 ){
                        calMovePos        = collPos;
                        calBestDis        = dis;
                        calBestId        = i;
                    }
                }
                AppDebug.CollCnt ++;
            }
            }
            else{
            for( int i=0; i<trgShape.EntryNum; i++ ){

                float a = (calMovePos.Dot( trgShape.Triangle[i].Plane.Nor ) + trgShape.Triangle[i].Plane.D);
                if( a >= checDis || a <= -checDis ){
                    continue;
                }

                if( DemoGame.CommonCollision.CheckLineAndTriangle( moveCap.Line, trgShape.Triangle[i], ref collPos ) == true ){
                    float dis = Common.VectorUtil.Distance( collPos, moveCap.StartPos );
                    if( dis < calBestDis || calBestId < 0 ){
                        calMovePos        = collPos;
                        calBestDis        = dis;
                        calBestId        = i;
                    }
                }
                AppDebug.CollCnt ++;
            }
            }

            if( calBestId >= 0 ){
            return true;
            }
            return false;
        }
开发者ID:hatano0x06,项目名称:Coroppoxus,代码行数:56,代码来源:CollisionSphereMove.cs

示例2: AnyOrthogonalShouldWork

        public void AnyOrthogonalShouldWork()
        {

            var r = new Random();
            for (int i = 0; i < 1000; i++)
            {
                var v = new Vector3((double) r.NextDouble(), (double) r.NextDouble(), (double) r.NextDouble());
                var o = v.Orthogonal();
                v.Dot(o).Should().BeApproximately(0, 1e-9);

            }
            
        }
开发者ID:Weingartner,项目名称:SolidworksAddinFramework,代码行数:13,代码来源:Vector3ExtensionsSpec.cs

示例3: CheckNearDis

        /// 最近接距離を求める
        public float CheckNearDis( Vector3 pos )
        {
            float isDis = 0.0f;
            float bestDis = 0.0f;

            /// 面単位で確認すればいいので1つ飛ばしで判定
            for( int i=0; i<EntryNum; i+=2 ){
            isDis = pos.Dot( Triangle[i].Plane.Nor ) + Triangle[i].Plane.D;
            if( i == 0 || isDis > bestDis ){
                bestDis = isDis;
            }
            }
            return bestDis;
        }
开发者ID:hatano0x06,项目名称:Coroppoxus,代码行数:15,代码来源:ShapeFrustum.cs

示例4: CheckNearDis

        /// 最近接距離を求める
        public float CheckNearDis( Vector3 pos )
        {
            float isDis = 0.0f;
            float bestDis = 0.0f;

            /// 上面
            bestDis = pos.Dot( Triangle[0].Plane.Nor ) + Triangle[0].Plane.D;

            /// 下面
            bestDis = pos.Dot( Triangle[1].Plane.Nor ) + Triangle[1].Plane.D;
            if( isDis > bestDis ){
            bestDis = isDis;
            }

            /// 右側面
            bestDis = pos.Dot( Triangle[EntryNum-4].Plane.Nor ) + Triangle[EntryNum-4].Plane.D;
            if( isDis > bestDis ){
            bestDis = isDis;
            }

            /// 左側面
            bestDis = pos.Dot( Triangle[EntryNum-2].Plane.Nor ) + Triangle[EntryNum-2].Plane.D;
            if( isDis > bestDis ){
            bestDis = isDis;
            }

            /// 遠面
            for( int i=0; i<objDivisionNum; i++ ){
            isDis = pos.Dot( Triangle[i*4+2].Plane.Nor ) + Triangle[i*4+2].Plane.D;
            if( i == 0 || isDis > bestDis ){
                bestDis = isDis;
            }
            }

            return bestDis;
        }
开发者ID:hatano0x06,项目名称:Coroppoxus,代码行数:37,代码来源:ShapeFan.cs

示例5: GetRotationAngle

		public static double GetRotationAngle(
			Vector3 rotationStatus,
			double rotationValue,
			Vector3 rotationAxis)
		{
			double angle = 0.0;

			if (rotationStatus.Dot (rotationAxis) >= 0.0) 
			{
				angle = 2.0 * Math.Atan2 (rotationStatus.Length (), rotationValue);
			} 
			else 
			{
				angle = 2.0 * Math.Atan2 (rotationStatus.Length (), -rotationValue);
			}

			return (angle > Math.PI) ? angle - 2.0 * Math.PI : angle;
		}
开发者ID:PieterMarius,项目名称:PhysicsEngine,代码行数:18,代码来源:JacobianCommon.cs

示例6: Reflect

 /// <summary>
 ///   <para>Reflects a vector off the plane defined by a normal.</para>
 /// </summary>
 /// <param name="inDirection"></param>
 /// <param name="inNormal"></param>
 public static Vector3<byte> Reflect(this Vector3<byte> inDirection, Vector3<byte> inNormal)
 {
     //In case of bytes it is -2 * some byte (which is byte). Dot product is closed under bytes so this is valid for bytes.
     byte twoTimesDotNDir = (byte)(-2 * (int)inNormal.Dot(inDirection));
     //this operation is also closed for bytes. We do not need to make an extension method.
     return (twoTimesDotNDir * inNormal) + inDirection;
 }
开发者ID:HelloKitty,项目名称:Testity,代码行数:12,代码来源:Vector3Extensions.cs

示例7: Project

        /// <summary>
        ///   <para>Projects a vector onto another vector.</para>
        /// </summary>
        /// <param name="vector"></param>
        /// <param name="onNormal"></param>
        public static Vector3<float> Project(this Vector3<float> vector, Vector3<float> onNormal)
        {
            //return ProjectInternalGeneric(vector, onNormal);
            float single = onNormal.Dot(onNormal);

            if (single < Vector3<float>.kEpsilon)
            {
                return Vector3<float>.zero;
            }

            return (onNormal * vector.Dot(onNormal)) * (1.0f / single);
        }
开发者ID:HelloKitty,项目名称:Testity,代码行数:17,代码来源:Vector3Extensions.cs

示例8: ProcessTriangle

        public override void ProcessTriangle(ref Vector3 point0, ref Vector3 point1, ref Vector3 point2, int partId, int triangleIndex)
        {
            Vector3 v10 = point1 - point0;
            Vector3 v20 = point2 - point0;

            Vector3 triangleNormal = v10.Cross(v20);

            float dist;
            point0.Dot(ref triangleNormal, out dist);
            float distA = triangleNormal.Dot(From) - dist;
            float distB = triangleNormal.Dot(To) - dist;

            if (distA * distB >= 0.0f)
            {
                return; // same sign
            }

            if (((Flags & EFlags.FilterBackfaces) != 0) && (distA <= 0.0f))
            {
                // Backface, skip check
                return;
            }


            float proj_length = distA - distB;
            float distance = (distA) / (proj_length);
            // Now we have the intersection point on the plane, we'll see if it's inside the triangle
            // Add an epsilon as a tolerance for the raycast,
            // in case the ray hits exacly on the edge of the triangle.
            // It must be scaled for the triangle size.

            if (distance < HitFraction)
            {
                float edgeTolerance = triangleNormal.LengthSquared;
                edgeTolerance *= -0.0001f;
                Vector3 point = Vector3.Lerp(From, To, distance);
                {
                    Vector3 v0p; v0p = point0 - point;
                    Vector3 v1p; v1p = point1 - point;
                    Vector3 cp0; cp0 = v0p.Cross(v1p);

                    float dot;
                    cp0.Dot(ref triangleNormal, out dot);
                    if (dot >= edgeTolerance)
                    {
                        Vector3 v2p; v2p = point2 - point;
                        Vector3 cp1;
                        cp1 = v1p.Cross(v2p);
                        cp1.Dot(ref triangleNormal, out dot);
                        if (dot >= edgeTolerance)
                        {
                            Vector3 cp2;
                            cp2 = v2p.Cross(v0p);

                            cp2.Dot(ref triangleNormal, out dot);
                            if (dot >= edgeTolerance)
                            {
                                //@BP Mod
                                // Triangle normal isn't normalized
                                triangleNormal.Normalize();

                                //@BP Mod - Allow for unflipped normal when raycasting against backfaces
                                if (((Flags & EFlags.KeepUnflippedNormal) == 0) && (distA <= 0.0f))
                                {
                                    triangleNormal = -triangleNormal;
                                }
                                HitFraction = ReportHit(ref triangleNormal, distance, partId, triangleIndex);
                            }
                        }
                    }
                }
            }
        }
开发者ID:sinkingsugar,项目名称:BulletSharpPInvoke,代码行数:73,代码来源:RaycastCallback.cs

示例9: return

        public static IBody2 CreateSemiCirclularSheet
            ( this IModeler modeler
            , Vector3 center
            , Vector3 vNormal
            , Vector3 vRef // Horizontal  
            , double radius)
        {
            // Should be orthogonal
            Debug.Assert(vRef.Dot(vNormal)<1e-9);

            var math = SwAddinBase.Active.Math;
            var centerSw = center.ToSwMathPoint();
            var vNormalSw = vNormal.ToSwMathPoint();
            var vNormalOrthSw = vRef.ToSWVector(math).Normalise();

            var centerDbls = centerSw.ArrayData;
            var vNormalDbls = vNormalSw.ArrayData;
            var vNormalOrthDbls = vNormalOrthSw.ArrayData;

            var surf = (Surface) modeler.CreatePlanarSurface2(centerDbls, vNormalDbls, vNormalOrthDbls);


            var startPoint = center + radius*vRef.Unit();
            var endPoint = center - radius*vRef.Unit();

            var startPointDbls = startPoint.ToDoubles();
            var endPointDbls = endPoint.ToDoubles();

            
            var arco = modeler.CreateArc
                        (centerDbls, vNormalDbls, radius, startPointDbls, endPointDbls);

            var arc = (Curve) arco;
            var arcStartPoint = startPoint;
            var arcEndPoint = endPoint;

            var trimmedArc = arc.CreateTrimmedCurve2(arcStartPoint.X,arcStartPoint.Y,arcStartPoint.Z,arcEndPoint.X,arcEndPoint.Y,arcEndPoint.Z);
            var line = modeler.CreateTrimmedLine(arcEndPoint, arcStartPoint);
            return (IBody2) surf.CreateTrimmedSheet(new[] {trimmedArc, line});
        }
开发者ID:Weingartner,项目名称:SolidworksAddinFramework,代码行数:40,代码来源:ModellerExtensions.cs

示例10: FromAxisAngle

        public static Vector4 FromAxisAngle(Vector3 axis, float angle)
        {
            if (axis.Dot() == 0.0f)
                return Identity;

            Vector4 result = Identity;

            angle *= 0.5f;
            axis.Normalize();
            result._x = axis._x * (float)System.Math.Sin(angle);
            result._y = axis._y * (float)System.Math.Sin(angle);
            result._z = axis._z * (float)System.Math.Sin(angle);
            result._w = (float)System.Math.Cos(angle);

            return result.Normalize();
        }
开发者ID:blahblahblahblah831,项目名称:brawltools2,代码行数:16,代码来源:Vector4.cs

示例11: LinePlaneIntersect

        public static bool LinePlaneIntersect(Vector3 lineStart, Vector3 lineEnd, Vector3 planePoint, Vector3 planeNormal, out Vector3 result)
        {
            Vector3 diff = lineEnd - lineStart;
            float scale = -planeNormal.Dot(lineStart - planePoint) / planeNormal.Dot(diff);

            if (float.IsNaN(scale) || scale < 0.0f || scale > 1.0f)
            {
                result = new Vector3();
                return false;
            }

            result = lineStart + (diff * scale);
            return true;
        }
开发者ID:blahblahblahblah831,项目名称:brawltools2,代码行数:14,代码来源:Maths.cs

示例12: dot

        public void dot() {
            var a = new Vector3(5, 2, -1);
            var b = new Vector3(3, -3, 0);

            Assert.Equal(9, a.Dot(b));
            Assert.Equal(9, b.Dot(a));
        }
开发者ID:aarondandy,项目名称:vertesaur,代码行数:7,代码来源:Vector3Facts.cs

示例13: CheckTriangle

        /// ラインと三角形との衝突
        public bool CheckTriangle( DemoGame.GeometryLine moveLine, ShapeTriangles trgShape )
        {
            Vector3 collPos = new Vector3(0,0,0);

            calMovePos = moveLine.EndPos;
            calBestDis = -1.0f;
            calBestId  = -1;

            float checDis = moveLine.Length + collCheckDis;

            for( int i=0; i<trgShape.EntryNum; i++ ){

            float a = (calMovePos.Dot( trgShape.Triangle[i].Plane.Nor ) + trgShape.Triangle[i].Plane.D);
            if( a >= checDis || a <= -checDis ){
                continue;
            }

            if( DemoGame.CommonCollision.CheckLineAndTriangle( moveLine, trgShape.Triangle[i], ref collPos ) == true ){
                float dis = Common.VectorUtil.Distance( collPos, moveLine.StartPos );
                if( dis < calBestDis || calBestId < 0 ){
                    calMovePos        = collPos;
                    calBestDis        = dis;
                    calBestId        = i;
                }
            }
            }

            if( calBestId >= 0 ){
            return true;
            }
            return false;
        }
开发者ID:hatano0x06,项目名称:Coroppoxus,代码行数:33,代码来源:CollisionPointMove.cs

示例14: GetClosestPtPosRay

        /// 点と線分の最近接点を算出
        public static float GetClosestPtPosRay( Vector3 trgPos, Vector3 trgRay, Vector3 trgRayPos, ref Vector3 cPos )
        {
            Vector3 ab, ca;
            float a_t;
            float a_dotCA;
            float a_dotAA;

            ab = trgRay;
            ca = trgPos - trgRayPos;

            a_dotCA = ca.Dot( ab );
            a_dotAA = ab.Dot( ab );

            if( a_dotAA <= epsilon ){
            a_t = 0.0f;
            }
            else{
            a_t = (a_dotCA / a_dotAA);
            }
            //		if( a_t < epsilon ){
            //			a_t = 0.0f;
            //		}
            //		else if( a_t > 1.0f ){
            //			a_t = 1.0f;
            //		}

            /// 最近接点の算出
            cPos.X = trgRayPos.X + ( a_t * ab.X );
            cPos.Y = trgRayPos.Y + ( a_t * ab.Y );
            cPos.Z = trgRayPos.Z + ( a_t * ab.Z );

            /// 最近接点と点との距離を返す
            Vector3 calVec = trgPos - cPos;
            float dis = FMath.Sqrt( calVec.Dot(calVec) );

            return dis;
        }
开发者ID:hatano0x06,项目名称:Coroppoxus,代码行数:38,代码来源:CommonCollision.cs

示例15: LineSphereIntersect

        public static bool LineSphereIntersect(Vector3 start, Vector3 end, Vector3 center, float radius, out Vector3 result)
        {
            Vector3 diff = end - start;
            float a = diff.Dot();

            if (a > 0.0f)
            {
                float b = 2 * diff.Dot(start - center);
                float c = (center.Dot() + start.Dot()) - (2 * center.Dot(start)) - (radius * radius);

                float magnitude = (b * b) - (4 * a * c);

                if (magnitude >= 0.0f)
                {
                    magnitude = (float)Math.Sqrt(magnitude);
                    a *= 2;

                    float scale = (-b + magnitude) / a;
                    float dist2 = (-b - magnitude) / a;

                    if (dist2 < scale)
                        scale = dist2;

                    result = start + (diff * scale);
                    return true;
                }
            }

            result = new Vector3();
            return false;
        }
开发者ID:blahblahblahblah831,项目名称:brawltools2,代码行数:31,代码来源:Maths.cs


注:本文中的System.Vector3.Dot方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。