创建矩形阵列
 
 

This example creates a circle and then performs a rectangular array of the circle, creating five rows and five columns of circles.

本例创建一个圆,然后对该圆执行矩形阵列操作,创建 5 行 5 列的圆。

VB.NET

Imports Autodesk.AutoCAD.Runtime
Imports Autodesk.AutoCAD.ApplicationServices
Imports Autodesk.AutoCAD.DatabaseServices
Imports Autodesk.AutoCAD.Geometry
 
Public Shared Function PolarPoints(ByVal pPt As Point2d, _
                                   ByVal dAng As Double, _
                                   ByVal dDist As Double)
 
  Return New Point2d(pPt.X + dDist * Math.Cos(dAng), _
                     pPt.Y + dDist * Math.Sin(dAng))
End Function
 
<CommandMethod("RectangularArrayObject")> _
Public Sub RectangularArrayObject()
  '' 获得当前文档和数据库   Get the current document and database
  Dim acDoc As Document = Application.DocumentManager.MdiActiveDocument
  Dim acCurDb As Database = acDoc.Database
 
  ''启动一个事务   Start a transaction
  Using acTrans As Transaction = acCurDb.TransactionManager.StartTransaction()
 
      '' 以只读方式打开块表记录   Open the Block table record for read
      Dim acBlkTbl As BlockTable
      acBlkTbl = acTrans.GetObject(acCurDb.BlockTableId, _
                                   OpenMode.ForRead)
 
      '' 以写方式打开模型空间块表记录   Open the Block table record Model space for write
      Dim acBlkTblRec As BlockTableRecord
      acBlkTblRec = acTrans.GetObject(acBlkTbl(BlockTableRecord.ModelSpace), _
                                      OpenMode.ForWrite)
 
      '' 在点 2,2 创建一个半径为0.5的圆    Create a circle that is at 2,2 with a radius of 0.5
      Dim acCirc As Circle = New Circle()
      acCirc.SetDatabaseDefaults()
      acCirc.Center = New Point3d(2, 2, 0)
      acCirc.Radius = 0.5
 
      '' 添加新对象到块表记录和事务中   Add the new object to the block table record and the transaction
      acBlkTblRec.AppendEntity(acCirc)
      acTrans.AddNewlyCreatedDBObject(acCirc, True)
 
      '' 创建一个5行5列的矩形阵列   Create a rectangular array with 5 rows and 5 columns
      Dim nRows As Integer = 5
      Dim nColumns As Integer = 5
 
      '' 设置行和列的偏移距离和阵列角度  Set the row and column offsets along with the base array angle
      Dim dRowOffset As Double = 1
      Dim dColumnOffset As Double = 1
      Dim dArrayAng As Double = 0
 
      ''获得当前用户坐标系的X轴的角度   Get the angle from X for the current UCS 
      Dim curUCSMatrix As Matrix3d = acDoc.Editor.CurrentUserCoordinateSystem
      Dim curUCS As CoordinateSystem3d = curUCSMatrix.CoordinateSystem3d
      Dim acVec2dAng As Vector2d = New Vector2d(curUCS.Xaxis.X, _
                                                curUCS.Xaxis.Y)
 
      ''如果用户坐标系是旋转过的,就调整阵列角度   If the UCS is rotated, adjust the array angle accordingly
      dArrayAng = dArrayAng + acVec2dAng.Angle
 
      '' 使用对象范围的左上角作为阵列的基点  Use the upper-left corner of the objects extents for the array base point
      Dim acExts As Extents3d = acCirc.Bounds.GetValueOrDefault()
      Dim acPt2dArrayBase As Point2d = New Point2d(acExts.MinPoint.X, _
                                                   acExts.MaxPoint.Y)
 
      ''跟踪每行中创建的对象   Track the objects created for each column
      Dim acDBObjCollCols As DBObjectCollection = New DBObjectCollection()
      acDBObjCollCols.Add(acCirc)
 
      ''创建用于首列的对象份数   Create the number of objects for the first column
      Dim nColumnsCount As Integer = 1
      While (nColumns > nColumnsCount)
          Dim acEntClone As Entity = acCirc.Clone()
          acDBObjCollCols.Add(acEntClone)
 
          '' 为副本计算新的基点  Caclucate the new point for the copied object (move)
          Dim acPt2dTo As Point2d = PolarPoints(acPt2dArrayBase, _
                                                dArrayAng, _
                                                dColumnOffset * nColumnsCount)
 
          Dim acVec2d As Vector2d = acPt2dArrayBase.GetVectorTo(acPt2dTo)
          Dim acVec3d As Vector3d = New Vector3d(acVec2d.X, acVec2d.Y, 0)
          acEntClone.TransformBy(Matrix3d.Displacement(acVec3d))
 
          acBlkTblRec.AppendEntity(acEntClone)
          acTrans.AddNewlyCreatedDBObject(acEntClone, True)
 
          nColumnsCount = nColumnsCount + 1
      End While
 
      '' 使用弧度设置一个90度的值   Set a value in radians for 90 degrees
      Dim dAng As Double = Math.PI / 2
 
      '' 追踪每行和每列中创建的对象  Track the objects created for each row and column
      Dim acDBObjCollLvls As DBObjectCollection = New DBObjectCollection()
 
      For Each acObj As DBObject In acDBObjCollCols
          acDBObjCollLvls.Add(acObj)
      Next
 
      ''创建每行中所需数量的对象   Create the number of objects for each row
      For Each acEnt As Entity In acDBObjCollCols
          Dim nRowsCount As Integer = 1
 
          While (nRows > nRowsCount)
              Dim acEntClone As Entity = acEnt.Clone()
              acDBObjCollLvls.Add(acEntClone)
 
              '' 计算每个副本的新的基点  Caclucate the new point for the copied object (move)
              Dim acPt2dTo As Point2d = PolarPoints(acPt2dArrayBase, _
                                                    dArrayAng + dAng, _
                                                    dRowOffset * nRowsCount)
 
              Dim acVec2d As Vector2d = acPt2dArrayBase.GetVectorTo(acPt2dTo)
              Dim acVec3d As Vector3d = New Vector3d(acVec2d.X, acVec2d.Y, 0)
              acEntClone.TransformBy(Matrix3d.Displacement(acVec3d))
 
              acBlkTblRec.AppendEntity(acEntClone)
              acTrans.AddNewlyCreatedDBObject(acEntClone, True)
 
              nRowsCount = nRowsCount + 1
          End While
      Next
 
      '' 保存新对象到数据库中   Save the new objects to the database
      acTrans.Commit()
  End Using
End Sub

C#

using Autodesk.AutoCAD.Runtime;
using Autodesk.AutoCAD.ApplicationServices;
using Autodesk.AutoCAD.DatabaseServices;
using Autodesk.AutoCAD.Geometry;
 
static Point2d PolarPoints(Point2d pPt, double dAng, double dDist)
{
  return new Point2d(pPt.X + dDist * Math.Cos(dAng),
                     pPt.Y + dDist * Math.Sin(dAng));
}
 
[CommandMethod("RectangularArrayObject")]
public static void RectangularArrayObject()
{
  // 获得当前文档和数据库   Get the current document and database
  Document acDoc = Application.DocumentManager.MdiActiveDocument;
  Database acCurDb = acDoc.Database;
 
  // 启动一个事务  Start a transaction
  using (Transaction acTrans = acCurDb.TransactionManager.StartTransaction())
  {
      // 以只读方式打开块表记录   Open the Block table record for read
      BlockTable acBlkTbl;
      acBlkTbl = acTrans.GetObject(acCurDb.BlockTableId,
                                   OpenMode.ForRead) as BlockTable;
 
      // 以写方式打开模型空间块表记录   Open the Block table record Model space for write
      BlockTableRecord acBlkTblRec;
      acBlkTblRec = acTrans.GetObject(acBlkTbl[BlockTableRecord.ModelSpace],
                                      OpenMode.ForWrite) as BlockTableRecord;
 
      // 在点 2,2 创建一个半径为0.5的圆    Create a circle that is at 2,2 with a radius of 0.5
      Circle acCirc = new Circle();
      acCirc.SetDatabaseDefaults();
      acCirc.Center = new Point3d(2, 2, 0);
      acCirc.Radius = 0.5;
 
      // 添加新对象到块表记录和事务中   Add the new object to the block table record and the transaction
      acBlkTblRec.AppendEntity(acCirc);
      acTrans.AddNewlyCreatedDBObject(acCirc, true);
 
      // 创建一个5行5列的矩形阵列   Create a rectangular array with 5 rows and 5 columns
      int nRows = 5;
      int nColumns = 5;
 
      // 设置行和列的偏移距离和阵列角度  Set the row and column offsets along with the base array angle
      double dRowOffset = 1;
      double dColumnOffset = 1;
      double dArrayAng = 0;
 
      // Get the angle from X for the current UCS 
      Matrix3d curUCSMatrix = acDoc.Editor.CurrentUserCoordinateSystem;
      CoordinateSystem3d curUCS = curUCSMatrix.CoordinateSystem3d;
      Vector2d acVec2dAng = new Vector2d(curUCS.Xaxis.X,
                                         curUCS.Xaxis.Y);
 
      // If the UCS is rotated, adjust the array angle accordingly
      dArrayAng = dArrayAng + acVec2dAng.Angle;
 
      // Use the upper-left corner of the objects extents for the array base point
      Extents3d acExts = acCirc.Bounds.GetValueOrDefault();
      Point2d acPt2dArrayBase = new Point2d(acExts.MinPoint.X,
                                            acExts.MaxPoint.Y);
 
      // Track the objects created for each column
      DBObjectCollection acDBObjCollCols = new DBObjectCollection();
      acDBObjCollCols.Add(acCirc);
 
      // Create the number of objects for the first column
      int nColumnsCount = 1;
      while (nColumns > nColumnsCount)
      {
          Entity acEntClone = acCirc.Clone() as Entity;
          acDBObjCollCols.Add(acEntClone);
 
          // Caclucate the new point for the copied object (move)
          Point2d acPt2dTo = PolarPoints(acPt2dArrayBase,
                                         dArrayAng,
                                         dColumnOffset * nColumnsCount);
 
          Vector2d acVec2d = acPt2dArrayBase.GetVectorTo(acPt2dTo);
          Vector3d acVec3d = new Vector3d(acVec2d.X, acVec2d.Y, 0);
          acEntClone.TransformBy(Matrix3d.Displacement(acVec3d));
 
          acBlkTblRec.AppendEntity(acEntClone);
          acTrans.AddNewlyCreatedDBObject(acEntClone, true);
 
          nColumnsCount = nColumnsCount + 1;
      }
 
      // Set a value in radians for 90 degrees
      double dAng = Math.PI / 2;
 
      // Track the objects created for each row and column
      DBObjectCollection acDBObjCollLvls = new DBObjectCollection();
 
      foreach (DBObject acObj in acDBObjCollCols)
      {
          acDBObjCollLvls.Add(acObj);
      }
 
      // Create the number of objects for each row
      foreach (Entity acEnt in acDBObjCollCols)
      {
          int nRowsCount = 1;
 
          while (nRows > nRowsCount)
          {
              Entity acEntClone = acEnt.Clone() as Entity;
              acDBObjCollLvls.Add(acEntClone);
 
              // Caclucate the new point for the copied object (move)
              Point2d acPt2dTo = PolarPoints(acPt2dArrayBase,
                                             dArrayAng + dAng,
                                             dRowOffset * nRowsCount);
 
              Vector2d acVec2d = acPt2dArrayBase.GetVectorTo(acPt2dTo);
              Vector3d acVec3d = new Vector3d(acVec2d.X, acVec2d.Y, 0);
              acEntClone.TransformBy(Matrix3d.Displacement(acVec3d));
 
              acBlkTblRec.AppendEntity(acEntClone);
              acTrans.AddNewlyCreatedDBObject(acEntClone, true);
 
              nRowsCount = nRowsCount + 1;
          }
      }
 
      // 保存新对象到数据库中   Save the new objects to the database
      acTrans.Commit();
  }
}
VBA/ActiveX 代码参考