乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 66|回复: 3

打印所有打开的dwg (PS选项卡)

[复制链接]

57

主题

235

帖子

3

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
463
发表于 2007-2-22 10:55:01 | 显示全部楼层 |阅读模式
有人有任何代码可以循环遍历所有打开的dwg并在每个dwg上绘制所有PS选项卡吗?

本帖以下内容被隐藏保护;需要你回复后,才能看到!

游客,如果您要查看本帖隐藏内容请回复
回复

使用道具 举报

57

主题

235

帖子

3

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
463
发表于 2007-2-22 11:30:13 | 显示全部楼层
不完全是,但是修改我的东西会很容易
回复

使用道具 举报

57

主题

235

帖子

3

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
463
发表于 2007-2-22 11:31:13 | 显示全部楼层
每个布局是否使用相同的打印设置?
回复

使用道具 举报

57

主题

235

帖子

3

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
463
发表于 2007-2-22 11:40:05 | 显示全部楼层
这应该可以让您开始
  1. Option Explicit
  2. Public Sub PlotAll()
  3.       Dim dwg As AcadDocument, dwgs As AcadDocuments
  4.       Set dwgs = Application.Documents
  5.       Dim PSLayout As AcadLayout, PSLayouts As AcadLayouts
  6.       For Each dwg In dwgs
  7.             Set PSLayouts = ThisDrawing.Layouts
  8.             For Each PSLayout In PSLayouts
  9.                   SetupAndPlot
  10.             Next
  11.       Next
  12. End Sub
  13. Private Sub SetupAndPlot()      'ByRef Plotter As String, CTB As String, SIZE As String, PSCALE As String, ROT As String) ' either pass these or hard code below
  14.       Dim Layout As AcadLayout
  15.       On Error GoTo Err_Control
  16.       Set Layout = ThisDrawing.ActiveLayout
  17.       Layout.RefreshPlotDeviceInfo
  18.       Layout.ConfigName = Plotter    ' CALL PLOTTER
  19.       Layout.PlotType = acExtents
  20.       Layout.PlotRotation = ROT    ' CALL ROTATION
  21.       Layout.StyleSheet = CTB    ' CALL CTB FILE
  22.       Layout.PlotWithPlotStyles = True
  23.       Layout.PlotViewportBorders = False
  24.       Layout.PlotViewportsFirst = True
  25.       Layout.CanonicalMediaName = SIZE    ' CALL SIZE
  26.       Layout.PaperUnits = acInches
  27.       Layout.StandardScale = PSCALE    'CALL PSCALE
  28.       Layout.ShowPlotStyles = False
  29.       ThisDrawing.Plot.NumberOfCopies = 1
  30.       Layout.CenterPlot = True
  31.       Layout.ScaleLineweights = False
  32.       Layout.RefreshPlotDeviceInfo
  33.       ThisDrawing.Regen acAllViewports
  34.       ZoomExtents
  35.       Set Layout = Nothing
  36.       ThisDrawing.Save
  37.       ThisDrawing.Plot.PlotToDevice
  38.       ThisDrawing.Close (True)
  39. Exit_Here:
  40.       Exit Sub
  41. Err_Control:
  42.       Select Case Err.Number
  43.             Case "-2145320861"
  44.                   MsgBox "Unable to Save Drawing- " & Err.Description
  45.             Case "-2145386493"
  46.                   MsgBox "Drawing is setup for Named Plot Styles." & (Chr(13)) & (Chr(13)) & "Run CONVERTPSTYLES command", vbCritical, "Change Plot Style"
  47.             Case Else
  48.                   MsgBox "Unknown Error " & Err.Number
  49.       End Select
  50. End Sub
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-7 09:41 , Processed in 2.160554 second(s), 60 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表