QQ登录

只需一步,快速开始

登录 | 注册 | 找回密码

三维网

 找回密码
 注册

QQ登录

只需一步,快速开始

展开

通知     

查看: 4133|回复: 23
收起左侧

[已解决] 草图中有N多个无规则的圆,如何操作可以快捷得到所有圆的圆心(对象为点)并删除圆

[复制链接]
发表于 2011-4-27 16:42:02 | 显示全部楼层 |阅读模式 来自: 中国江苏苏州

马上注册,结识高手,享用更多资源,轻松玩转三维网社区。

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

x
草图中有N多个无规则的圆,如何操作可以快捷得到所有圆的圆心(对象为点)并删除圆
发表于 2011-4-28 08:00:08 | 显示全部楼层 来自: 日本
 楼主| 发表于 2011-4-28 08:47:04 | 显示全部楼层 来自: 中国江苏苏州
2# hongwei_1987jp
1 E5 h; q) S# D! m7 ]1 u
7 a1 _8 G% U1 N" f3 T1 T6 w/ X2 z  C5 F1 C$ y* `
没有理解我意思:草图有N个圆而没有每一个圆的圆心(我只圆心这个点)!?我现在要通过这些圆来获得这些圆的圆心,而不要圆,就是要获得这些圆的所有Position,也就是通过草图圆获得圆心们这个对象
发表于 2011-4-28 15:59:43 | 显示全部楼层 来自: 中国山东济南
2# hongwei_1987jp  
3 v% Y1 w" [  \+ J' P* m$ F5 O4 l7 Z3 \) R! l% u' B# D' u
- b1 |, j+ Y  [1 W
没有理解我意思:草图有N个圆而没有每一个圆的圆心(我只圆心这个点)!?我现在要通过这些圆来获得这些圆的圆心,而不要圆,就是要获得这些圆的所有Position,也就是通过草图圆获得圆心们 ...  V& B3 o. F4 H3 f
574395 发表于 2011-4-28 08:47 http://www.3dportal.cn/discuz/images/common/back.gif
, C: U% G1 B2 b3 O8 ?2 I, M. j
- H3 a# G0 q$ _% Q" l
有圆必有圆心!!!划线连接各圆圆心(自动捕捉)。
 楼主| 发表于 2011-4-28 16:21:48 | 显示全部楼层 来自: 中国江苏苏州
4# oneteng
, l) q+ n0 b1 j6 o0 i" q8 M3 T
$ Z" a* L/ @; s具体如何自动捕捉??一个一个点圆心??
发表于 2011-4-28 17:58:21 | 显示全部楼层 来自: 日本
本帖最后由 hongwei_1987jp 于 2011-4-28 18:00 编辑
" `- L& M# q0 K$ c0 `8 V: W: k6 d- @9 L$ ]* o1 r# B
就是不明白,你为什么要先画圆,找圆点,然后又不要那个圆,就是要圆点?+ j  j& S  M) w

8 |& Y% {  z# q0 d# c9 Q5 a3 q直接画**点**不行吗?7 z3 K9 m) l% l9 C4 A# m
& B+ N2 ~1 y% T" ~' J% }3 i$ z
你要想利用这些点去做草图,用曲线直接连接那些点不就可以了吗???
发表于 2011-4-28 18:08:17 | 显示全部楼层 来自: 日本
直白的說,全選。。。。圓心會自動標出。。。。。如果你要連接所有圓心。。那只能一個一個點。。。。
发表于 2011-4-29 08:23:38 | 显示全部楼层 来自: 中国广东佛山
1,写一个宏.& v7 C/ E+ e3 x* ]
2,把草图名称改为"草图n".
2 }4 f: g: u1 U0 p: G2 y! H) S9 @! ~6 P- n2 g, Z; V2 G& K9 ^
  K3 O" ^5 y5 E
Sub main()
) w2 M& Z5 {* U7 L    Dim swApp  As SldWorks.SldWorks
" L9 Q# U; r9 B3 Y' |    Dim swModel As SldWorks.ModelDoc27 B* ?! @- ]) g; Q6 G2 ?8 k# {
    Dim swPart As SldWorks.PartDoc/ X% `0 X- A# ]  a' K
    Dim swSelMgr  As SldWorks.SelectionMgr
* _# x2 [0 K7 k7 {& _) ]' g. t    Dim swFeat  As SldWorks.Feature
# Y' h; g8 V3 }, C* F5 d, e& s# ?    Dim swSketch   As SldWorks.Sketch9 E  D, H8 x2 Q- u
    Dim mySelectData As SldWorks.SelectData
& W. B- ~  G0 f$ v/ U    Dim skContour As SketchContour
! U- G% k4 K+ O' ]7 y, b4 e    Dim vEdges As Variant, myEdge As SldWorks.Edge
) x% x: m! L$ L3 k, ]    Dim NumArcs, uuu As Long2 r; P- R; M! S) ^* ?
    Dim vArcs As Variant
+ p/ x" d3 p& o7 R; n# X    Dim vSkContours As Variant
2 _9 o; E9 o( S5 y# K& k! z1 i    Dim vSkSeg  As Variant: s" q- v# A1 L: l8 {) y( K
    Dim i As Integer
& w# V1 ], F+ c" e. `' X2 L* Z    Dim boolstatus As Boolean2 g2 q) F" H4 }8 H
    Dim swSkArc As SldWorks.SketchArc
. ?* E/ b# ?5 ^" J, F    Dim swCurve As SldWorks.Curve: O" i5 d+ p- A2 V
    Dim skPoint As Object# s6 B; b7 l1 D$ p5 z8 H2 x) q! N# B7 n
    Set swApp = Application.SldWorks
4 D( M; _/ h1 D: Z+ ^+ [+ K    Set swModel = swApp.ActiveDoc7 ]- M" Q6 F1 U9 Q1 b# V0 q, F, X
    Set swPart = swModel& W; `0 N" ?7 V) n0 e( g
    Set swSelMgr = swModel.SelectionManager8 k5 N9 b* r! W; U% f
    Set mySelectData = swSelMgr.CreateSelectData
) R# f2 i' d7 @; d3 m    Set swFeat = swPart.FeatureByName("草图n")
0 j4 f6 p) R( o8 _. p7 x' k& X. A    Set swSketch = swFeat.GetSpecificFeature! ^3 f2 {* B2 L3 ~
    swModel.Extension.SelectByID2 "草图n", "SKETCH", 0, 0, 0, False, 0, Nothing, 06 S0 m, }, p9 v  o" C
    swModel.EditSketch- o0 l* V1 v9 u% m/ z) X- }
    If Not swSketch Is Nothing Then$ Q; k" S9 |. [; U' a
       NumArcs = swSketch.GetArcCount/ g9 u$ |( C, R# q. }$ O( k
       vSkContours = swSketch.GetSketchContours()9 r& v0 Y) W1 H2 S
       For i = 0 To UBound(vSkContours)
+ m" h7 r% M* K: H; u  M# ?4 c, W          vArcs = swSketch.GetArcs2
( `: D! o1 a) Q, V7 E% P          If IsEmpty(vArcs) Then Exit Sub3 u* _2 {- @2 a! }3 ]5 W' [
            Set skContour = vSkContours(i)
! B( F5 l, R6 H7 Z            If Not skContour Is Nothing Then9 @: D. D1 b$ U& w' D8 P5 k
               If skContour.IsClosed = 1 Then
. t% b" b6 |: }- r9 k5 V( K' n) ^6 {                  uuu = skContour.GetEdgesCount- M& T' g) J; t. c
                  If uuu = 1 Then
: {# V9 ^$ V' s5 k) E! ^0 `2 ~                       vEdges = skContour.GetEdges* s. ?) r/ g/ z. A
                       Set myEdge = vEdges(0)7 c. V6 z  G2 [7 Y: E4 Y3 k
                       Set swCurve = myEdge.GetCurve
) G$ i8 o) H. [! \) C                       vSkSeg = swCurve.CircleParams
% p" i( X; W1 I! d* W                        boolstatus = skContour.Select2(False, mySelectData)
4 ?! J- k( N) ?                        swModel.EditDelete
0 A) i+ b$ F+ q5 U% l6 p& T                        Set skPoint = swModel.SketchManager.CreatePoint(vSkSeg(0), vSkSeg(1), 0)
/ i* a$ ]1 K2 C                   End If
! w* h9 x' N/ H9 y               End If8 Y# j' o1 b/ {+ ]( X
            End If4 g( o% u1 A2 b8 \+ A3 y
       Next i4 l1 P7 `  a: u- B1 Z; G; @
       swModel.SketchManager.InsertSketch True
, F9 @- Z- `( e. L    End If
+ @/ x3 \. o; P1 W# [# s- v# LEnd Sub

评分

参与人数 1三维币 +5 收起 理由
wlkr + 5 应助

查看全部评分

 楼主| 发表于 2011-4-29 09:55:42 | 显示全部楼层 来自: 中国江苏苏州
8# yjyeming
7 r6 V% f) u' E9 h# O! @; ]0 C. P" V: i

* g6 e/ o! ^- ?  m! w/ R谢谢,要的就是这个效果,找到知音了,代码自己写的吗
发表于 2011-4-29 10:41:33 | 显示全部楼层 来自: 中国广东佛山
代码肯定要自己写的..
 楼主| 发表于 2011-4-29 11:35:00 | 显示全部楼层 来自: 中国江苏苏州
10# yjyeming
  {( k' o" I3 y# w9 Q) A, e' n
9 s/ q5 R+ h4 N, B+ J0 z1 S9 R有做过其他开发吗?能不能把草图对象名设置成任意,不必每次手动改名。另外,能否添加一种对象不是草图而是实体面的情况?该怎么做,谢谢
发表于 2011-4-29 12:19:58 | 显示全部楼层 来自: 中国上海
本帖最后由 w_hs1 于 2011-4-29 12:28 编辑 8 u/ b5 I% o& Q5 @' \3 b. y
' o3 y; Q$ }8 p+ M; f, R
要完全满足楼主的要求,的确只能设计一个宏了。
, I4 e% i) K2 ~. o但是楼主的原意恐怕只是要将一个草图引入到异型孔的位置草图中去(见楼主的另一个帖子的22楼说明,下面是该贴的链接),那么只要用复制就行了。
7 H. _+ p; d  J' l) U0 Dhttp://www.3dportal.cn/discuz/viewthread.php?tid=1031387&extra=page%3D1
& X7 p; |. `4 g. b! R3 v* m8 u0 b) s8 ~

' b( p' s9 d0 f8 k2 m/ }7 l1、用异型孔向导在任意位置建立一个孔" k8 n+ \- D- x$ _+ s# K
2、将草图2复制进草图4(复制结果会有一个位移)
, D$ i# P* @- g3、选定草图中全部复制过来的元素,按住shift键同步移动到远处(由于移动时不能捕捉,不能直接移到正确位置。移到远处是准备将来删除时便于框选)9 F  B8 J' d7 k3 {0 A
4、按住Ctrl键,将这些元素复制到位(利用捕捉)
1 k2 E7 `$ w- v$ C  U' e$ V' l# T5、删除多余的元素1 z, b) |! [6 I" @! I  ]
6、退出草图,完成任务# R# r8 A+ c) ]$ U2 f  J' L
- N* _* s+ _( J( X8 ?9 t
复制位置草图.gif

评分

参与人数 1三维币 +5 收起 理由
wlkr + 5 应助

查看全部评分

 楼主| 发表于 2011-4-29 12:55:32 | 显示全部楼层 来自: 中国江苏苏州
12# w_hs1 . I- C6 o. }2 k
/ I  ~) W. C% ?8 s/ V! s1 n9 \
是的,就是这样的意思,总之就是为了利用虚拟异型孔草图点位置来驱动零部件的装配关系,而宏的利用就是由原先的草图圆阵到你给出的草图2中点阵的过程,由于SW本身不带该功能,就想到了API和QT工具,另外做完该步骤之后在装配的时候还有点小窍门,一言以蔽之,整个过程就是通过草图来虚拟的达到驱动阵列零部件的功能,整个流程还需进一步简化和完善,主要还是在草图2的产生这一过程上,试用过程中选择对象一般都是实体面或单独的曲面,当然也有上面程序中给出的草图对象。还是感谢各位,学到新的一招,Ctrl+草图对象、、、之前都是点移动工具来完成移动,谢谢!!希望得到更多交流和探讨学习!
发表于 2011-4-29 15:12:16 | 显示全部楼层 来自: 中国广东佛山
11# 574395 3 D0 w% G" `) z" k
太容易了.
 楼主| 发表于 2011-4-29 16:45:49 | 显示全部楼层 来自: 中国江苏苏州
14# yjyeming
2 r) @# M; _! Z. e, R
' P$ j4 D& T+ n. w. C/ ~能给个代码分享下?敢问您平时做二次开发多吗?想详细交流下
发表于 2011-4-30 11:27:35 | 显示全部楼层 来自: 中国广东深圳
上面说的是在固弄玄虚吗。用草图与表格不一样能达到上面的效果吗。
发表于 2011-4-30 14:22:29 | 显示全部楼层 来自: 中国浙江杭州
要圆心何必删除圆呢 框选所有圆转成构造线就行了啊 既得到了圆心又不受圆的影响
发表于 2011-4-30 15:58:00 | 显示全部楼层 来自: 中国上海
要圆心何必删除圆呢 框选所有圆转成构造线就行了啊 既得到了圆心又不受圆的影响5 }5 n0 K( L. `) G) H" Y" B" j' i% W+ U
ffddjj 发表于 2011-4-30 14:22 http://www.3dportal.cn/discuz/images/common/back.gif
# `* c8 C' t( d% L
0 {) [( k' C/ }0 K4 N2 r8 t
楼主的这些点是用于异型孔特征的位置草图。此草图只承认其中的草图点,其它元素虽然可以存在,但系统对那些元素视而不见。 而其它草图中的圆心虽然也是草图中的一个点,但不是“草图点”,即不是在“*”记号下生成的点,因此即便将这些圆(包括它的圆心)用“转换实体引用”的功能置于位置草图中,再做异型孔时,系统仍然对它视而不见。可见楼主要的是真正的草图点,而不仅仅是圆心点。8 {# A( z$ f  d' M
其实我也被楼主搞糊涂了,楼主的原始目的是为了在装配体中阵列零件(见http://www.3dportal.cn/discuz/viewthread.php?tid=1031387&extra=page%3D1),如果是为了布置标准紧固件,完全可以直接用SW的智能扣件功能,自动的将合适的紧固件加到适合的孔中去。如果不是安装紧固件,考虑到通常这些孔多是用孔特征或阵列孔来实现的,孔特征和阵列可以作为装配体中特征阵列的驱动特征使用,同样可以方便地阵列零件。偏偏楼主又必须用几个孔特征来布置原始零件的孔位(我也不知是何缘故),又不想做几次孔特征,于是我给了一个用装配体中虚拟孔特征作为特征阵列的驱动特征。本来我觉得问题应该解决了,随之楼主又觉得在虚拟孔特征中一个个点出孔位来太麻烦(其实不麻烦呀,点每个孔位点,只要捕捉重合点,一点一个,很方便地,难道楼主要弄几百个点,怕手酸麽?)于是我就建议利用原零件孔特征的位置草图点进行复制的办法。现在楼主又要求空的大小是随意的,我真的搞不清楼主倒弄什么东西了。

评分

参与人数 1三维币 +3 收起 理由
chenjun520601 + 3 继续应助

查看全部评分

 楼主| 发表于 2011-5-3 09:55:15 | 显示全部楼层 来自: 中国江苏苏州
18# w_hs1
4 Y3 X5 H: h+ z1 ]1 t) y* c/ Y: g+ B6 U& v) I- s2 R- z
感谢关注,下面我来回答下,对于要点而不要圆的问题,分析的极是,我要的对象是点,仅仅是点,当然可以无视圆,把它们构造掉,具体原因是因为在装配体中做阵列的时候对象只能是点(这个可以自己去试下)。+ \6 K1 C4 e8 I9 \
0 o# j8 a9 e) C$ j: I, t
对于SW智能扣件及智能特征,我之前也做过相关尝试,的确,你是不懂的,实际是有几百个点,当你做为一个设计者的时候,这个时候你倘若一个个去手动点选圆心来获得点的苦衷是不言而喻的,所以,软件自动化也是异常重要和不可或缺;“偏偏楼主又必须用几个孔特征来布置原始零件的孔位(我也不知是何缘故)”零件中本来这些位置是孔特征,在装配的时候也正是孔轴装配所以是在原有孔的位置上,我怀疑您是否进行实战设计的经验。不过讨论这些也没什么意义,能达到目的才是唯一的目的,仅仅说明SW本身的功能的确是有待开发完善,以上仅个人见解
发表于 2011-5-24 09:55:32 | 显示全部楼层 来自: 中国浙江杭州
楼主是不是用草图阵列?我是先画圆再在圆心上画点,再删了圆,笨办法
 楼主| 发表于 2011-5-25 08:31:16 | 显示全部楼层 来自: 中国江苏苏州
20# gxj528 ! `0 h6 ~9 Q8 N+ U, u
9 r% e2 T+ A# P
是的,但是当草图中的圆的个数上百之后您依旧会选择一个个去选中再删除吗?用上面的代码可以遍历草图圆并取圆心删除圆
 楼主| 发表于 2011-5-26 07:55:41 | 显示全部楼层 来自: 中国江苏苏州
22# jlj694167857 可以拿宏试一下效果就知道了
发表于 2011-6-18 21:48:23 | 显示全部楼层 来自: 中国天津
有点像闷大的一道题。等放假时候研究一下。
发表于 2011-6-18 22:49:08 | 显示全部楼层 来自: 中国山东淄博
没细看,但是知道,繁琐的操作还可以使用宏的搞定,这就够了。
发表回复
您需要登录后才可以回帖 登录 | 注册

本版积分规则


Licensed Copyright © 2016-2020 http://www.3dportal.cn/ All Rights Reserved 京 ICP备13008828号

小黑屋|手机版|Archiver|三维网 ( 京ICP备2023026364号-1 )

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