Specifies the origin of the UCS, block, hatch, or raster image in WCS coordinates.
Supported platforms: Windows only
VBA:
object.Origin
Type: Block, GeomapImage, Hatch, ModelSpace, PaperSpace, RasterImage, UCS, Wipeout
The objects this property applies to.
Read-only: No
Type: Variant (two- or three-element array of doubles)
2D Point: The X and Y values representing the origin relative to the lower-left corner of the media.
3D Point: A 3D WCS coordinate specifying the origin of the object.
Hatch: This property is the origin coordinates for the pattern of the hatch entity.
VBA:
Sub Example_Origin() ' This example creates a UCS and returns its origin. Dim viewportObj As AcadViewport ' Set the viewportObj variable to the activeviewport Set viewportObj = ThisDrawing.ActiveViewport ' Create a new UCS with origin 2, 2, 0 Dim ucsObj As AcadUCS Dim origin(0 To 2) As Double Dim xAxisPoint(0 To 2) As Double Dim yAxisPoint(0 To 2) As Double origin(0) = 2: origin(1) = 2: origin(2) = 0 xAxisPoint(0) = 3: xAxisPoint(1) = 2: xAxisPoint(2) = 0 yAxisPoint(0) = 2: yAxisPoint(1) = 3: yAxisPoint(2) = 0 Set ucsObj = ThisDrawing.UserCoordinateSystems.Add(origin, xAxisPoint, yAxisPoint, "UCS1") ThisDrawing.ActiveUCS = ucsObj viewportObj.UCSIconOn = True viewportObj.UCSIconAtOrigin = True ThisDrawing.ActiveViewport = viewportObj ' Display the current origin for the new UCS MsgBox "The origin of the UCS is: " & ucsObj.origin(0) & ", " & ucsObj.origin(1) & ", " & ucsObj.origin(2), , "Origin Example" ' Change the origin of the UCS origin(0) = 4: origin(1) = 4: origin(2) = 0 ucsObj.origin = origin ' Reset the active UCS and viewport to see the change ThisDrawing.ActiveUCS = ucsObj ThisDrawing.ActiveViewport = viewportObj MsgBox "The origin of the UCS is now: " & ucsObj.origin(0) & ", " & ucsObj.origin(1) & ", " & ucsObj.origin(2), , "Origin Example" End Sub
Visual LISP:
(vl-load-com) (defun c:Example_Origin() ;; This example creates a UCS and returns its origin. (setq acadObj (vlax-get-acad-object)) (setq doc (vla-get-ActiveDocument acadObj)) ;; Set the viewportObj variable to the activeviewport (setq viewportObj (vla-get-ActiveViewport doc)) ;; Create a new UCS with origin 2, 2, 0 (setq origin (vlax-3d-point 2 2 0) xAxisPoint (vlax-3d-point 3 2 0) yAxisPoint (vlax-3d-point 2 3 0)) (setq ucsObj (vla-Add (vla-get-UserCoordinateSystems doc) origin xAxisPoint yAxisPoint "UCS1")) (vla-put-ActiveUCS doc ucsObj) (vla-put-UCSIconOn viewportObj :vlax-true) (vla-put-UCSIconAtOrigin viewportObj :vlax-true) (vla-put-ActiveViewport doc viewportObj) ;; Display the current origin for the new UCS (alert (strcat "The origin of the UCS is: " (rtos (vlax-safearray-get-element (vlax-variant-value (vla-get-Origin ucsObj)) 0) 2) ", " (rtos (vlax-safearray-get-element (vlax-variant-value (vla-get-Origin ucsObj)) 1) 2) ", " (rtos (vlax-safearray-get-element (vlax-variant-value (vla-get-Origin ucsObj)) 2) 2))) ;; Change the origin of the UCS (setq origin (vlax-3d-point 4 4 0)) (vla-put-Origin ucsObj origin) ;; Reset the active UCS and viewport to see the change (vla-put-ActiveUCS doc ucsObj) (vla-put-ActiveViewport doc viewportObj) (alert (strcat "The origin of the UCS is now: " (rtos (vlax-safearray-get-element (vlax-variant-value (vla-get-Origin ucsObj)) 0) 2) ", " (rtos (vlax-safearray-get-element (vlax-variant-value (vla-get-Origin ucsObj)) 1) 2) ", " (rtos (vlax-safearray-get-element (vlax-variant-value (vla-get-Origin ucsObj)) 2) 2))) )