SetCustomScale 方法 (ActiveX)
设置布局或打印配置的自定义比例。 支持的平台:仅限 Windows 签名VBA: object.SetCustomScale Numerator, Denominator
返回值 (RetVal)无返回值。 言论可以在属性中找到 Numerator 参数的单位。PaperUnits 分子和分母参数必须大于零。 在重新生成图形之前,通过此方法所做的更改将不可见。使用该方法重新生成图形。Regen 例子VBA: Sub Example_SetCustomScale() ' This example will access the Layouts collection for the current drawing ' and list basic information about the custom scale for each Layout. ' It will then change the custom scale information for model space and re-display ' the scale information. Dim Layouts As AcadLayouts, Layout As ACADLayout Dim msg As String Dim Numerator As Double, Denominator As Double Dim Measurement As String ' Display current scale information GoSub DISPLAY_SCALE_INFO ' Modify scale Numerator = 1 Denominator = 1 ThisDrawing.Layouts("Model").SetCustomScale Numerator, Denominator ThisDrawing.Regen acAllViewports ' Display new scale information GoSub DISPLAY_SCALE_INFO Exit Sub DISPLAY_SCALE_INFO: ' Get layouts collection from document object Set Layouts = ThisDrawing.Layouts msg = vbCrLf & vbCrLf ' Start with a space ' Get the scale information of every layout in this drawing For Each Layout In Layouts msg = msg & Layout.name & vbCrLf ' Get scale information Layout.GetCustomScale Numerator, Denominator ' Identify whether inches or millimeters are being used. Measurement = IIf(Layout.PaperUnits = acInches, " inch(es)", " millimeter(s)") ' Format for display msg = msg & vbTab & "Contains " & Numerator & Measurement & vbCrLf msg = msg & vbTab & "Contains " & Denominator & " drawing units" & vbCrLf msg = msg & "_____________________" & vbCrLf Next ' Display custom scale information MsgBox "Custom scale information for the current drawing is: " & msg Return End Sub 可视化 LISP: (vl-load-com) (defun c:Example_SetCustomScale() ;; This example will access the Layouts collection for the current drawing ;; and list basic information about the custom scale for each Layout. ;; It will then change the custom scale information for model space and re-display ;; the scale information. (setq acadObj (vlax-get-acad-object)) (setq doc (vla-get-ActiveDocument acadObj)) ;; Display current scale information (setq Layouts (vla-get-Layouts doc)) (setq msg "") ;; Get the scale information of every layout in this drawing (vlax-for Layout Layouts (setq msg (strcat msg (vla-get-Name Layout) "\n")) ;; Get scale information (vla-GetCustomScale Layout 'Numerator 'Denominator) ;; Are we using inches or millimeters (setq Measurement (if (= (vla-get-PaperUnits Layout) acInches) " inch(es)\n" " millimeter(s)\n")) ;; Format for display (setq msg (strcat msg " Contains " (rtos Numerator 2) Measurement " Contains " (rtos Denominator 2) " drawing units\n" "_____________________\n")) ) ;; Display custom scale information (alert (strcat "Custom scale information for the current drawing is: " msg)) ;; Modify scale (setq Numerator 1 Denominator 1) (vla-SetCustomScale (vla-Item (vla-get-Layouts doc) "Model") Numerator Denominator) (vla-Regen doc acAllViewports) ;; Display new scale information (setq Layouts (vla-get-Layouts doc)) (setq msg "") ;; Get the scale information of every layout in this drawing (vlax-for Layout Layouts (setq msg (strcat msg (vla-get-Name Layout) "\n")) ;; Get scale information (vla-GetCustomScale Layout 'Numerator 'Denominator) ;; Are we using inches or millimeters (setq Measurement (if (= (vla-get-PaperUnits Layout) acInches) " inch(es)\n" " millimeter(s)\n")) ;; Format for display (setq msg (strcat msg " Contains " (rtos Numerator 2) Measurement " Contains " (rtos Denominator 2) " drawing units\n" "_____________________\n")) ) ;; Display custom scale information (alert (strcat "Custom scale information for the current drawing is: " msg)) ) |
|Archiver|CAD开发者社区 ( 苏ICP备2022047690号-1 苏公网安备32011402011833)
GMT+8, 2025-1-19 06:40
Powered by Discuz! X3.4
Copyright © 2001-2021, Tencent Cloud.