15/06/2019
Нахождение геометрического центра для LWPOLYLINE, 3DPoly и 2DPoly
К сожалению, в AutoCAD API нет прямого метода для определения геометрического центра всех трех типов полилиний. Можно использовать библиотеки топологии, чтобы выяснить это. Проще же всего преобразовать LWPOLYLINE, AcDb2dPolyline, AcDb3dPolyline в AcDbRegion в памяти и применить AutoCAD API для получения геометрического центра области (AcDbRegion).
Код - C#: [Выделить]
- [CommandMethod("GCTR")]
- public static void GC() {
- var doc = AcCoreApp.DocumentManager.MdiActiveDocument;
- var db = doc.Database;
- var ed = doc.Editor;
- var tid = ObjectId.Null;
- Point2d centroid = Point2d.Origin;
- using(Transaction tr = db.TransactionManager.StartTransaction()) {
- try {
- TypedValue[] acTypValAr = {
- new TypedValue((int) DxfCode.Operator, "")
- };
- // Назначаем критерий фильтра объекту SelectionFilter
- SelectionFilter acSelFtr = new SelectionFilter(acTypValAr);
- // Запрашиваем объекты в области чертежа
- PromptSelectionResult acSSPrompt;
- acSSPrompt = ed.GetSelection(acSelFtr);
- // Если статус OK – объекты выбраны
- if (acSSPrompt.Status == PromptStatus.OK) {
- SelectionSet acSSet = acSSPrompt.Value;
- foreach(SelectedObject so in acSSet) {
- var pline = tr.GetObject(so.ObjectId, OpenMode.ForRead) as Entity;
- // Преобразуем объекты в Region в памяти.
- using(DBObjectCollection segments = new DBObjectCollection()) {
- pline.Explode(segments);
- DBObjectCollection regions = Region.CreateFromCurves(segments);
- foreach(Region r in regions) {
- // Находим центроид лежащий в плоскости XY МСК:
- Point3d origin = Point3d.Origin;
- Vector3d xAxis = Vector3d.XAxis;
- Vector3d yAxis = Vector3d.YAxis;
- centroid = r.AreaProperties(ref origin, ref xAxis, ref yAxis).Centroid;
- CenterMarkEntity(centroid);
- }
- }
- ed.WriteMessage($ "\nГеометрический центр {pline.GetRXClass().DxfName}:{centroid}");
- }
- tr.Commit();
- }
- } catch (Autodesk.AutoCAD.Runtime.Exception ex) {
- ed.WriteMessage(ex.ToString());
- }
- }
- }
- public static void CenterMarkEntity(Point2d p) {
- var doc = AcCoreApp.DocumentManager.MdiActiveDocument;
- var db = doc.Database;
- var ed = doc.Editor;
- using(Transaction t = db.TransactionManager.StartTransaction()) {
- short mode = (short) AcCoreApp.GetSystemVariable("PDMODE");
- if (mode == 0) {
- AcCoreApp.SetSystemVariable("PDMODE", 99);
- }
- var ms = t.GetObject(SymbolUtilityServices.GetBlockModelSpaceId(db), OpenMode.ForWrite) as BlockTableRecord;
- DBPoint dbPt = new DBPoint(new Point3d(p.X, p.Y, .0)) {
- ColorIndex = 3
- };
- ms.AppendEntity(dbPt);
- t.AddNewlyCreatedDBObject(dbPt, true);
- t.Commit();
- }
- }
Автор перевода: Александр Ривилис
Отредактировано 15.06.2019 в 20:23:04
Обсуждение: http://adn-cis.org/forum/index.php?topic=
Опубликовано 15.06.2019Отредактировано 15.06.2019 в 20:23:04