當前位置: 首頁>>代碼示例>>C#>>正文


C# Line.Project方法代碼示例

本文整理匯總了C#中System.Line.Project方法的典型用法代碼示例。如果您正苦於以下問題:C# Line.Project方法的具體用法?C# Line.Project怎麽用?C# Line.Project使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Line的用法示例。


在下文中一共展示了Line.Project方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: DelayedHitCalc

 public override RealHitInfo DelayedHitCalc(Line by, HitInfo hit)
 {
     RealHitInfo realHit = new RealHitInfo();
     realHit.HitStuff = Surface;
     realHit.Pigment = Pigment;
     realHit.Normal = new Line();
     realHit.Normal.Start = by.Project(hit.HitDist);
     realHit.Normal.Direct.Dx = 0;
     realHit.Normal.Direct.Dy = 0;
     realHit.Normal.Direct.Dz = 0;
     switch (hit.SurfaceIndex)
     {
         case 0:
             Point hitLoc2 = inv.Apply(realHit.Normal.Start);
             realHit.Normal.Direct.Dx = hitLoc2.X;
             realHit.Normal.Direct.Dy = hitLoc2.Y;
             realHit.Normal.Direct.Dz = hitLoc2.Z;
             break;
         default:
             throw new InvalidOperationException("Invalid surface index in hitdata");
     }
     Vector before = realHit.Normal.Direct;
     realHit.Normal.Direct = trans.Apply(realHit.Normal.Direct);
     if (realHit.Normal.Direct.Dot(by.Direct) > 0)
     {
         realHit.Normal.Direct.ScaleSelf(-1.0);
     }
     return realHit;
 }
開發者ID:Tilps,項目名稱:Stash,代碼行數:29,代碼來源:Sphere.cs

示例2: DelayedHitCalc

 public override RealHitInfo DelayedHitCalc(Line by, HitInfo hit)
 {
     RealHitInfo realHit = new RealHitInfo();
     realHit.Normal = new Line();
     realHit.HitStuff = Surface;
     realHit.Pigment = Pigment;
     realHit.Normal.Start = by.Project(hit.HitDist);
     realHit.Normal.Direct.Dx = 0;
     realHit.Normal.Direct.Dy = 0;
     realHit.Normal.Direct.Dz = 0;
     Point hitLoc;
     Vector deviance = new Vector();
     if (rounded)
     {
         hitLoc = inv.Apply(realHit.Normal.Start);
         if (hit.SurfaceIndex != 5 || !RoundedTopOnly)
         {
             if (hitLoc.X < -1 + XRounding)
             {
                 switch (hit.SurfaceIndex)
                 {
                     case 2:
                     case 3:
                     case 4:
                     case 5:
                         deviance.Dx = -1 + (hitLoc.X + 1) / XRounding;
                         break;
                 }
             }
             if (hitLoc.X > 1 - XRounding)
             {
                 switch (hit.SurfaceIndex)
                 {
                     case 2:
                     case 3:
                     case 4:
                     case 5:
                         deviance.Dx = 1 - (1 - hitLoc.X) / XRounding;
                         break;
                 }
             }
             if (hitLoc.Y < -1 + YRounding)
             {
                 switch (hit.SurfaceIndex)
                 {
                     case 0:
                     case 1:
                     case 4:
                     case 5:
                         deviance.Dy = -1 + (hitLoc.Y + 1) / YRounding;
                         break;
                 }
             }
             if (hitLoc.Y > 1 - YRounding)
             {
                 switch (hit.SurfaceIndex)
                 {
                     case 0:
                     case 1:
                     case 4:
                     case 5:
                         deviance.Dy = 1 - (1 - hitLoc.Y) / YRounding;
                         break;
                 }
             }
         }
         if (!RoundedTopOnly && hitLoc.Z < -1 + ZRounding)
         {
             switch (hit.SurfaceIndex)
             {
                 case 0:
                 case 1:
                 case 2:
                 case 3:
                     deviance.Dz = -1 +(hitLoc.Z + 1) / ZRounding;
                     break;
             }
         }
         if (hitLoc.Z > 1 - ZRounding)
         {
             switch (hit.SurfaceIndex)
             {
                 case 0:
                 case 1:
                 case 2:
                 case 3:
                     deviance.Dz = 1 - (1 - hitLoc.Z) / ZRounding;
                     break;
             }
         }
     }
     switch (hit.SurfaceIndex)
     {
         case 0:
             realHit.Normal.Direct.Dx = 1;
             break;
         case 1:
             realHit.Normal.Direct.Dx = -1;
             break;
         case 2:
//.........這裏部分代碼省略.........
開發者ID:Tilps,項目名稱:Stash,代碼行數:101,代碼來源:Box.cs

示例3: DelayedHitCalc

 public override RealHitInfo DelayedHitCalc(Line by, HitInfo hit)
 {
     RealHitInfo realHit = new RealHitInfo();
     realHit.HitStuff = Surface;
     realHit.Pigment = Pigment;
     realHit.Normal = new Line();
     realHit.Normal.Start = by.Project(hit.HitDist);
     realHit.Normal.Direct.Dx = 0;
     realHit.Normal.Direct.Dy = 0;
     realHit.Normal.Direct.Dz = 0;
     Point hitLoc;
     Vector deviance = new Vector();
     if (rounded)
     {
         hitLoc = inv.Apply(realHit.Normal.Start);
         if (hit.SurfaceIndex == 1 || (!RoundedTopOnly && hit.SurfaceIndex == 2))
         {
             double r = Math.Sqrt(hitLoc.X * hitLoc.X + hitLoc.Y * hitLoc.Y);
             if (r > 1 - RRounding)
             {
                 double dr = (1 - (1 - r) / RRounding) / (r);
                 deviance.Dx = hitLoc.X * dr;
                 deviance.Dy = hitLoc.Y * dr;
             }
         }
         if (!RoundedTopOnly && hitLoc.Z < -1 + ZRounding)
         {
             switch (hit.SurfaceIndex)
             {
                 case 0:
                     deviance.Dz = -1 + (hitLoc.Z + 1) / ZRounding;
                     break;
             }
         }
         if (hitLoc.Z > 1 - ZRounding)
         {
             switch (hit.SurfaceIndex)
             {
                 case 0:
                     deviance.Dz = 1 - (1 - hitLoc.Z) / ZRounding;
                     break;
             }
         }
     }
     switch (hit.SurfaceIndex)
     {
         case 0:
             Point hitLoc2 = inv.Apply(realHit.Normal.Start);
             realHit.Normal.Direct.Dx = hitLoc2.X;
             realHit.Normal.Direct.Dy = hitLoc2.Y;
             break;
         case 1:
             realHit.Normal.Direct.Dz = 1;
             break;
         case 2:
             realHit.Normal.Direct.Dz = -1;
             break;
         default:
             throw new InvalidOperationException("Invalid surface index in hitdata");
     }
     Vector before = realHit.Normal.Direct;
     realHit.Normal.Direct = trans.Apply(realHit.Normal.Direct);
     if (realHit.Normal.Direct.Dot(by.Direct) > 0)
     {
         if (rounded)
         {
             before.ScaleSelf(-1.0);
             deviance.ScaleSelf(-1.0);
         }
         else
             realHit.Normal.Direct.ScaleSelf(-1.0);
     }
     if (rounded)
     {
         realHit.Normal.Direct = before;
         realHit.Normal.Direct.Add(deviance);
         realHit.Normal.Direct = trans.Apply(realHit.Normal.Direct);
         if (realHit.Normal.Direct.Dot(by.Direct) > 0)
         {
             Vector perp1 = realHit.Normal.Direct.Cross(by.Direct);
             realHit.Normal.Direct = by.Direct.Cross(perp1);
         }
        }
     return realHit;
 }
開發者ID:Tilps,項目名稱:Stash,代碼行數:85,代碼來源:Cylinder.cs

示例4: AreLinesEqual

      private bool AreLinesEqual(Line line1, Line line2)
      {
         if (!line1.IsBound || !line2.IsBound)
         {
            // Two unbound lines are equal if they are going in the same direction and the origin
            // of one lies on the other one.
            return line1.Direction.IsAlmostEqualTo(line2.Direction) &&
               MathUtil.IsAlmostZero(line1.Project(line2.Origin).Distance);
         }

         for (int ii = 0; ii < 2; ii++)
         {
            if (line1.GetEndPoint(0).IsAlmostEqualTo(line2.GetEndPoint(ii)) &&
                line1.GetEndPoint(1).IsAlmostEqualTo(line2.GetEndPoint(1 - ii)))
               return true;
         }

         return false;
      }
開發者ID:whztt07,項目名稱:RevitCustomIFCexporter,代碼行數:19,代碼來源:IFCGridAxis.cs


注:本文中的System.Line.Project方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。