乐筑天下

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

[编程交流] vb。净选择点

[复制链接]

4

主题

8

帖子

4

银币

初来乍到

Rank: 1

铜币
20
发表于 2022-7-6 22:39:03 | 显示全部楼层 |阅读模式
我有一个代码可以创建一个选择窗口。
我需要编辑代码,以便用户可以选择屏幕上的窗口点,而不是硬编码的点
有什么想法吗?
 
 
  1. Public Class Class1
  2. <CommandMethod("selectwindowa")> _
  3. Public Sub selectwindowa()
  4. Dim mydwg As Document = DocumentManager.MdiActiveDocument
  5. Dim myeditor As Editor = DocumentManager.MdiActiveDocument.Editor
  6. Dim mypsr As PromptSelectionResult = mydwg.Editor.SelectWindow( _
  7. New Point3d(-2, -2, 0), New Point3d(2, 2, 0))
  8. If mypsr.Status = PromptStatus.OK Then
  9. Using myTrans As Transaction = mydwg.TransactionManager.StartTransaction
  10. For Each myObjectID As ObjectId In mypsr.Value.GetObjectIds
  11. Dim myEnt As Entity = myObjectID.GetObject(OpenMode.ForRead)
  12. MsgBox(myEnt.Layer & vbTab & myEnt.GeometricExtents.ToString)
  13. Next
  14. End Using
  15. End If
回复

使用道具 举报

10

主题

973

帖子

909

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
118
发表于 2022-7-6 23:25:56 | 显示全部楼层
获得两个用户选择点的一种方法是首先使用PromptPointOptions/Editor,同时向用户提供一些视觉反馈。GetPoint()/PromptPointResult交互以获取初始点。然后,该点可以与PromptCornerOptions/Editor一起使用。GetCorner()/PromptPointResult。这两点可以提供给编辑器选择方法。
回复

使用道具 举报

7

主题

12

帖子

5

银币

初来乍到

Rank: 1

铜币
35
发表于 2022-7-7 00:02:51 | 显示全部楼层
谢谢肖特,我试过你的建议,效果很好。
仅供参考最终代码如下
 
  1. Public Class Class1
  2. <CommandMethod("selectwindowa")> _
  3. Public Sub selectwindowa()
  4. Dim mydwg As Document = DocumentManager.MdiActiveDocument
  5. Dim myeditor As Editor = DocumentManager.MdiActiveDocument.Editor
  6. Dim myPPR As Point3d = myeditor.GetPoint("Select 1st Point: ").Value
  7. Dim myPPR1 As Point3d = myeditor.GetCorner("Select 2nd Point: ", myPPR).Value
  8. Dim mypsr As PromptSelectionResult = mydwg.Editor.SelectWindow( _
  9. myPPR, myPPR1)
  10. If mypsr.Status = PromptStatus.OK Then
  11. Using myTrans As Transaction = mydwg.TransactionManager.StartTransaction
  12. For Each myObjectID As ObjectId In mypsr.Value.GetObjectIds
  13. Dim myEnt As Entity = myObjectID.GetObject(OpenMode.ForRead)
  14. MsgBox(myEnt.Layer & vbTab & myEnt.GeometricExtents.ToString)
  15. Next
  16. End Using
  17. End If
  18. End Sub
  19. End Class
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-1-31 20:52 , Processed in 0.348097 second(s), 69 queries .

© 2020-2025 乐筑天下

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