Найти точку пересечения круга с линией в настройке AutoCAD с помощью vb.net
Для настройки autocad мне нужно найти точку пересечения круга с линией. Ниже приведен мой код, но он не возвращает мне точки пересечения.
Из-за ограничений, налагаемых на мою проблему, всегда будет хотя бы одна точка пересечения. Но я действительно не могу получить эту точку пересечения. Может ли кто-нибудь помочь мне показать путь к достижению того, что я хочу сделать?
Imports System
Imports System.Runtime.InteropServices
Imports System.Drawing
Imports Autodesk.AutoCAD.Runtime
Imports Autodesk.AutoCAD.DatabaseServices
Imports Autodesk.AutoCAD.Geometry
Imports Autodesk.AutoCAD.ApplicationServices
Imports Autodesk.AutoCAD.EditorInput
Imports Autodesk.AutoCAD.ApplicationServices.DocumentExtension
Namespace sweeping
Public Class intersecting
<CommandMethod("ITSSPS")>
Public Shared Sub SweepAlongPath()
Dim doc As Document = Application.DocumentManager.MdiActiveDocument
Dim db As Database = doc.Database
Dim ed As Editor = doc.Editor
Using tr As Transaction = db.TransactionManager.StartTransaction()
'getting point1
Dim ppo1 As PromptPointOptions = New PromptPointOptions(vbLf & "choose/click the centre of the first circle:")
Dim ppr1 As PromptPointResult = doc.Editor.GetPoint(ppo1)
Dim pt1 As Point3d = ppr1.Value
If ppr1.Status = PromptStatus.Cancel Then Exit Sub
Dim pdo11 As PromptDoubleOptions = New PromptDoubleOptions(vbLf & "The radius of the first cycle? Type 5 as 5.0")
Dim pdr11 As PromptDoubleResult = doc.Editor.GetDouble(pdo11)
Dim pd11 As Double = pdr11.Value
If pdr11.Status = PromptStatus.Cancel Then Exit Sub
Dim pdo12 As PromptDoubleOptions = New PromptDoubleOptions(vbLf & "What about the height? Type 5 as 5.0")
Dim pdr12 As PromptDoubleResult = doc.Editor.GetDouble(pdo12)
Dim pd12 As Double = pdr12.Value
If pdr12.Status = PromptStatus.Cancel Then Exit Sub
'getting point2
Dim ppo2 As PromptPointOptions = New PromptPointOptions(vbLf & "choose/click the centre of the second circle:")
Dim ppr2 As PromptPointResult = doc.Editor.GetPoint(ppo2)
Dim pt2 As Point3d = ppr2.Value
If ppr2.Status = PromptStatus.Cancel Then Exit Sub
Dim pdo21 As PromptDoubleOptions = New PromptDoubleOptions(vbLf & "The radius of the second cycle? Type 5 as 5.0")
Dim pdr21 As PromptDoubleResult = doc.Editor.GetDouble(pdo21)
Dim pd21 As Double = pdr21.Value
If pdr21.Status = PromptStatus.Cancel Then Exit Sub
Dim pdo22 As PromptDoubleOptions = New PromptDoubleOptions(vbLf & "What about the height? Type 5 as 5.0")
Dim pdr22 As PromptDoubleResult = doc.Editor.GetDouble(pdo22)
Dim pd22 As Double = pdr22.Value
If pdr22.Status = PromptStatus.Cancel Then Exit Sub
Dim line12 As Line = New Line(pt1, pt2)
Dim Cir1, Cir2 As Circle
Cir1 = New Circle() : Cir1.Center = pt1 : Cir1.Normal = New Vector3d(0, 0, 1) : Cir1.Radius = pd11
Cir2 = New Circle() : Cir2.Center = pt2 : Cir2.Normal = New Vector3d(0, 0, 1) : Cir2.Radius = pd21
Dim bt As BlockTable = tr.GetObject(db.BlockTableId, OpenMode.ForRead)
Dim btr As BlockTableRecord = tr.GetObject(bt(BlockTableRecord.ModelSpace), OpenMode.ForWrite)
Dim Cir11 As Entity = DirectCast(Cir1, Entity)
Dim line121 As Entity = DirectCast(line12, Entity)
btr.AppendEntity(Cir11)
tr.AddNewlyCreatedDBObject(Cir11, True)
btr.AppendEntity(line121)
tr.AddNewlyCreatedDBObject(line121, True)
Dim its3dpts As Point3dCollection = New Point3dCollection()
line121.IntersectWith(Cir11, Intersect.OnBothOperands, its3dpts, IntPtr.Zero, IntPtr.Zero)
For Each pt3d As Point3d In its3dpts
Dim ptt As Point3d = pt3d
Dim Cir3 As Circle = New Circle()
Cir3.Center = ptt : Cir3.Normal = New Vector3d(0, 0, 1) : Cir3.Radius = 450
ed.WriteMessage(pt3d.ToString)
btr.AppendEntity(Cir3)
tr.AddNewlyCreatedDBObject(Cir3, True)
Next
tr.Commit()
End Using
End Sub
End Class
End Namespace
Спасибо миллион тому, кто мне помогает.
1 ответ
Этот вызов IntersectWith должен работать. Я попробовал здесь, и это работает нормально. Вы уверены, что Круг и Линия действительно пересекаются?
Ниже мой тестовый код:
[CommandMethod("findIntersect")]
public static void CmdFindIntersect()
{
Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
ObjectId lineId = ed.GetEntity("Select line: ").ObjectId; // not safe, test only
ObjectId circleId = ed.GetEntity("Select circle: ").ObjectId; // not safe, test only
Database db = Application.DocumentManager.MdiActiveDocument.Database;
using (Transaction trans = db.TransactionManager.StartTransaction())
{
Line l = trans.GetObject(lineId, OpenMode.ForRead) as Line;
Circle c = trans.GetObject(circleId, OpenMode.ForRead) as Circle;
Point3dCollection intersectionPoints = new Point3dCollection();
l.IntersectWith(c, Intersect.OnBothOperands, intersectionPoints, IntPtr.Zero, IntPtr.Zero);
trans.Commit();
ed.WriteMessage("{0} intersection(s) found", intersectionPoints.Count);
}
}