找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2151|回复: 5

[讨论]:模型空间中多个视口同时平移视图的程序

[复制链接]
发表于 2005-1-5 14:29:47 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
这是自己编写的一个程序,功能如题。
但自觉这个程序还是很有问题,主要是由于每个视口在平移时都要重生成一次,如果图形较大运行就很慢。
所以在此仅作抛砖引玉,请各位高人多多指点。

  1.   [FONT=courier new]
  2. Option Explicit
  3. Sub vppan()
  4.    

  5.    
  6.     Dim vport As AcadViewport
  7.     Dim vport1 As AcadViewport
  8.     Dim pt1 As Variant
  9.     Dim pt2 As Variant
  10.     Dim pt_center As Variant
  11.     pt1 = ThisDrawing.Utility.GetPoint(, "请选择第一点:")
  12.     pt2 = ThisDrawing.Utility.GetPoint(ThisDrawing.Utility.TranslateCoordinates _
  13.         (pt1, acWorld, acUCS, False), "请选择下一点:")
  14.     pt1 = ThisDrawing.Utility.TranslateCoordinates(pt1, acWorld, acUCS, False)
  15.     pt2 = ThisDrawing.Utility.TranslateCoordinates(pt2, acWorld, acUCS, False)
  16.    
  17.    
  18.       
  19.         On Error Resume Next
  20.         ThisDrawing.SendCommand "-vports" & vbCr & "s" & vbCr & _
  21.             "akang_vport" & vbCr & "y" & vbCr
  22.         Set vport1 = ThisDrawing.ActiveViewport
  23.         'n = 1
  24.         For Each vport In ThisDrawing.Viewports
  25.             If vport.Name = "akang_vport" Then
  26.                 ThisDrawing.ActiveViewport = vport
  27.                 pt_center = vport.Center
  28.                 pt_center(0) = pt_center(0) - pt2(0) + pt1(0) '* (width1 / width2)
  29.                 pt_center(1) = pt_center(1) - pt2(1) + pt1(1) '* (width1 / width2)
  30.                 vport.Center = pt_center
  31.             End If
  32.         Next vport
  33.         ThisDrawing.ActiveViewport = vport1
  34. End Sub




  35.   [/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2014-3-25 14:34:00 | 显示全部楼层
谢谢楼主!又学一招。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1268个

财富等级: 财源广进

发表于 2014-3-25 16:06:49 来自手机 | 显示全部楼层
运行前关闭重生成,最后打开
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2021-12-6 10:30:57 | 显示全部楼层
不错不错 来学习一下
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 1094个

财富等级: 财源广进

发表于 2022-3-20 10:41:30 | 显示全部楼层
感谢楼主分享!回复看看。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2022-9-2 17:59:35 | 显示全部楼层
好东西,一直想要
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-11-15 15:23 , Processed in 0.186118 second(s), 41 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表