您可以通过裁剪图像来定义图像的显示和绘图区域。剪切边界必须是 2D 多边形或矩形,其顶点被约束为位于图像边界内。同一图像的多个实例可以具有不同的边界。 如果要显示或隐藏图像边界,请使用该属性,并使用该属性确定剪切边界是定义为矩形还是多边形。IsClippedClipBoundaryType 使用以下方法获取或设置图像的剪切边界:
裁剪光栅图像本示例在模型空间中添加光栅图像,然后根据裁剪边界裁剪该图像。此示例使用在 VBA 示例目录中找到的 WorldMap.tif 文件。如果没有此映像,或者它位于其他目录中,请修改代码以使用有效的路径和文件名。 VB.NETImports Autodesk.AutoCAD.Runtime Imports Autodesk.AutoCAD.ApplicationServices Imports Autodesk.AutoCAD.DatabaseServices Imports Autodesk.AutoCAD.Geometry <CommandMethod("ClippingRasterBoundary")> _ Public Sub ClippingRasterBoundary() ' Get the current database and start a transaction Dim acCurDb As Autodesk.AutoCAD.DatabaseServices.Database acCurDb = Application.DocumentManager.MdiActiveDocument.Database Using acTrans As Transaction = acCurDb.TransactionManager.StartTransaction() ' Define the name and image to use Dim strImgName As String = "WorldMap" Dim strFileName As String = "C:\AutoCAD\Sample\VBA\WorldMap.TIF" Dim acRasterDef As RasterImageDef Dim bRasterDefCreated As Boolean = False Dim acImgDefId As ObjectId ' Get the image dictionary Dim acImgDctID As ObjectId = RasterImageDef.GetImageDictionary(acCurDb) ' Check to see if the dictionary does not exist, it not then create it If acImgDctID.IsNull Then acImgDctID = RasterImageDef.CreateImageDictionary(acCurDb) End If ' Open the image dictionary Dim acImgDict As DBDictionary = acTrans.GetObject(acImgDctID, OpenMode.ForRead) ' Check to see if the image definition already exists If acImgDict.Contains(strImgName) Then acImgDefId = acImgDict.GetAt(strImgName) acRasterDef = acTrans.GetObject(acImgDefId, OpenMode.ForWrite) Else ' Create a raster image definition Dim acRasterDefNew As New RasterImageDef ' Set the source for the image file acRasterDefNew.SourceFileName = strFileName ' Load the image into memory acRasterDefNew.Load() ' Add the image definition to the dictionary acTrans.GetObject(acImgDctID, OpenMode.ForWrite) acImgDefId = acImgDict.SetAt(strImgName, acRasterDefNew) acTrans.AddNewlyCreatedDBObject(acRasterDefNew, True) acRasterDef = acRasterDefNew bRasterDefCreated = True End If ' Open the Block table 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) ' Create the new image and assign it the image definition Using acRaster As New RasterImage acRaster.ImageDefId = acImgDefId ' Use ImageWidth and ImageHeight to get the size of the image in pixels (1024 x 768). ' Use ResolutionMMPerPixel to determine the number of millimeters in a pixel so you ' can convert the size of the drawing into other units or millimeters based on the ' drawing units used in the current drawing. ' Define the width and height of the image Dim width As Vector3d Dim height As Vector3d ' Check to see if the measurement is set to English (Imperial) or Metric units If acCurDb.Measurement = MeasurementValue.English Then width = New Vector3d((acRasterDef.ResolutionMMPerPixel.X * acRaster.ImageWidth) / 25.4, 0, 0) height = New Vector3d(0, (acRasterDef.ResolutionMMPerPixel.Y * acRaster.ImageHeight) / 25.4, 0) Else width = New Vector3d(acRasterDef.ResolutionMMPerPixel.X * acRaster.ImageWidth, 0, 0) height = New Vector3d(0, acRasterDef.ResolutionMMPerPixel.Y * acRaster.ImageHeight, 0) End If ' Define the position for the image Dim insPt As New Point3d(5.0, 5.0, 0.0) ' Define and assign a coordinate system for the image's orientation Dim coordinateSystem As New CoordinateSystem3d(insPt, width * 2, height * 2) acRaster.Orientation = coordinateSystem ' Set the rotation angle for the image acRaster.Rotation = 0 ' Define the clipping boundary in drawing units Dim acPt2dColl As New Point2dCollection Dim acMat3d As Matrix3d = acRaster.PixelToModelTransform.Inverse() acPt2dColl.Add(New Point3d(5.5, 15, 0).TransformBy(acMat3d).Convert2d(New Plane())) acPt2dColl.Add(New Point3d(12.5, 15, 0).TransformBy(acMat3d).Convert2d(New Plane())) acPt2dColl.Add(New Point3d(12.5, 10.5, 0).TransformBy(acMat3d).Convert2d(New Plane())) acPt2dColl.Add(New Point3d(5.5, 10.5, 0).TransformBy(acMat3d).Convert2d(New Plane())) acPt2dColl.Add(New Point3d(5.5, 15, 0).TransformBy(acMat3d).Convert2d(New Plane())) ' Clip the image acRaster.SetClipBoundary(ClipBoundaryType.Rectangle, acPt2dColl) ' Enable the display of the clip acRaster.IsClipped = True ' Add the new object to the block table record and the transaction acBlkTblRec.AppendEntity(acRaster) acTrans.AddNewlyCreatedDBObject(acRaster, True) ' Connect the raster definition and image together so the definition ' does not appear as "unreferenced" in the External References palette. RasterImage.EnableReactors(True) acRaster.AssociateRasterDef(acRasterDef) If bRasterDefCreated Then acRasterDef.Dispose() End If End Using ' Save the new object to the database acTrans.Commit() ' Dispose of the transaction End Using End Sub C#using Autodesk.AutoCAD.Runtime; using Autodesk.AutoCAD.ApplicationServices; using Autodesk.AutoCAD.DatabaseServices; using Autodesk.AutoCAD.Geometry; [CommandMethod("ClippingRasterBoundary")] public void ClippingRasterBoundary() { // Get the current database and start a transaction Database acCurDb; acCurDb = Application.DocumentManager.MdiActiveDocument.Database; using (Transaction acTrans = acCurDb.TransactionManager.StartTransaction()) { // Define the name and image to use string strImgName = "WorldMap"; string strFileName = "C:\\AutoCAD\\Sample\\VBA\\WorldMap.TIF"; RasterImageDef acRasterDef; bool bRasterDefCreated = false; ObjectId acImgDefId; // Get the image dictionary ObjectId acImgDctID = RasterImageDef.GetImageDictionary(acCurDb); // Check to see if the dictionary does not exist, it not then create it if (acImgDctID.IsNull) { acImgDctID = RasterImageDef.CreateImageDictionary(acCurDb); } // Open the image dictionary DBDictionary acImgDict = acTrans.GetObject(acImgDctID, OpenMode.ForRead) as DBDictionary; // Check to see if the image definition already exists if (acImgDict.Contains(strImgName)) { acImgDefId = acImgDict.GetAt(strImgName); acRasterDef = acTrans.GetObject(acImgDefId, OpenMode.ForWrite) as RasterImageDef; } else { // Create a raster image definition RasterImageDef acRasterDefNew = new RasterImageDef(); // Set the source for the image file acRasterDefNew.SourceFileName = strFileName; // Load the image into memory acRasterDefNew.Load(); // Add the image definition to the dictionary acTrans.GetObject(acImgDctID, OpenMode.ForWrite); acImgDefId = acImgDict.SetAt(strImgName, acRasterDefNew); acTrans.AddNewlyCreatedDBObject(acRasterDefNew, true); acRasterDef = acRasterDefNew; bRasterDefCreated = true; } // Open the Block table 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; // Create the new image and assign it the image definition using (RasterImage acRaster = new RasterImage()) { acRaster.ImageDefId = acImgDefId; // Use ImageWidth and ImageHeight to get the size of the image in pixels (1024 x 768). // Use ResolutionMMPerPixel to determine the number of millimeters in a pixel so you // can convert the size of the drawing into other units or millimeters based on the // drawing units used in the current drawing. // Define the width and height of the image Vector3d width; Vector3d height; // Check to see if the measurement is set to English (Imperial) or Metric units if (acCurDb.Measurement == MeasurementValue.English) { width = new Vector3d((acRasterDef.ResolutionMMPerPixel.X * acRaster.ImageWidth) / 25.4, 0, 0); height = new Vector3d(0, (acRasterDef.ResolutionMMPerPixel.Y * acRaster.ImageHeight) / 25.4, 0); } else { width = new Vector3d(acRasterDef.ResolutionMMPerPixel.X * acRaster.ImageWidth, 0, 0); height = new Vector3d(0, acRasterDef.ResolutionMMPerPixel.Y * acRaster.ImageHeight, 0); } // Define the position for the image Point3d insPt = new Point3d(5.0, 5.0, 0.0); // Define and assign a coordinate system for the image's orientation CoordinateSystem3d coordinateSystem = new CoordinateSystem3d(insPt, width * 2, height * 2); acRaster.Orientation = coordinateSystem; // Set the rotation angle for the image acRaster.Rotation = 0; // Define the clipping boundary in drawing units Point2dCollection acPt2dColl = new Point2dCollection(); Matrix3d acMat3d = acRaster.PixelToModelTransform.Inverse(); acPt2dColl.Add(new Point3d(5.5, 15, 0).TransformBy(acMat3d).Convert2d(new Plane())); acPt2dColl.Add(new Point3d(12.5, 15, 0).TransformBy(acMat3d).Convert2d(new Plane())); acPt2dColl.Add(new Point3d(12.5, 10.5, 0).TransformBy(acMat3d).Convert2d(new Plane())); acPt2dColl.Add(new Point3d(5.5, 10.5, 0).TransformBy(acMat3d).Convert2d(new Plane())); acPt2dColl.Add(new Point3d(5.5, 15, 0).TransformBy(acMat3d).Convert2d(new Plane())); // Clip the image acRaster.SetClipBoundary(ClipBoundaryType.Rectangle, acPt2dColl); // Enable the display of the clip acRaster.IsClipped = true; // Add the new object to the block table record and the transaction acBlkTblRec.AppendEntity(acRaster); acTrans.AddNewlyCreatedDBObject(acRaster, true); // Connect the raster definition and image together so the definition // does not appear as "unreferenced" in the External References palette. RasterImage.EnableReactors(true); acRaster.AssociateRasterDef(acRasterDef); if (bRasterDefCreated) { acRasterDef.Dispose(); } } // Save the new object to the database acTrans.Commit(); // Dispose of the transaction } } VBA/ActiveX 代码参考Sub ClippingRasterBoundary() Dim insertionPoint(0 To 2) As Double Dim scalefactor As Double Dim rotationAngle As Double Dim imageName As String Dim rasterObj As AcadRasterImage imageName = "C:/AutoCAD/sample/VBA/WorldMap.TIF" insertionPoint(0) = 5 insertionPoint(1) = 5 insertionPoint(2) = 0 scalefactor = 2 rotationAngle = 0 ' Creates a raster image in model space Set rasterObj = ThisDrawing.ModelSpace.AddRaster(imageName, insertionPoint, _ scalefactor, rotationAngle) ' Establish the clip boundary with an array of points Dim clipPoints(0 To 9) As Double clipPoints(0) = 5.5: clipPoints(1) = 15 clipPoints(2) =12.5: clipPoints(3) = 15 clipPoints(4) = 12.5: clipPoints(5) = 10.5 clipPoints(6) = 5.5: clipPoints(7) = 10.5 clipPoints(8) = 5.5: clipPoints(9) = 15 ' Clip the image rasterObj.ClipBoundary clipPoints ' Enable the display of the clip rasterObj.ClippingEnabled = True ThisDrawing.Regen acActiveViewport End Sub 父主题: |
|Archiver|CAD开发者社区 ( 苏ICP备2022047690号-1 苏公网安备32011402011833)
GMT+8, 2025-1-8 19:42
Powered by Discuz! X3.4
Copyright © 2001-2021, Tencent Cloud.