PLM之家PLMHome-国产软件践行者

[二次开发源码] NX二次开发源码分享:显示面的法相方向

[复制链接]

2019-2-8 13:26:19 2847 1

admin 发表于 2019-2-8 12:58:52 |阅读模式

admin 楼主

2019-2-8 12:58:52

请使用QQ关联注册PLM之家,学习更多关于内容,更多精彩原创视频供你学习!

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

x

! x  G$ J! b) @# ~: n
! e, A0 k" X* K' U经常能用的到,通过选择面,显示临时法线方向和点!
  G: Q4 a/ |' O) v9 m2 p
0 ]5 _2 v' j7 L* @0 l& [% n5 @; Y# R, ?' M8 `% N8 b. \# r) S
[mw_shl_code=cpp,true]  static bool DisplayNormal(Face theFace)
: E# p1 y+ I8 R    {4 Z  T% ~, N- P) }; k. }$ S
        double[] param = new double[2];
; V2 t& x( [& c+ K% k; u$ U" u! J$ ^        double[] p1 = new double[3];
$ I1 h& I8 H* p+ }% G4 K        double[] u1 = new double[3];
$ c' R7 l1 h! `' ^, ^        double[] v1 = new double[3];
0 Y! s  B1 {$ p        double[] u2 = new double[3];1 h: b) A$ T4 Y
        double[] v2 = new double[3];2 K- x: }  _1 V# L2 S4 d
        double[] unit_norm = new double[3];" U% @( m2 L; Z
        double[] radii = new double[2];
  D4 ]& h+ M% `. l# K  n  Q) ^        double[] uv_min_max = new double[4];7 b3 e. H( i3 b
) q" ^5 w" B, n! v7 ^$ D/ J$ _! [" x- a
        theUFSession.Modl.AskFaceUvMinmax(theFace.Tag, uv_min_max);
1 Z. ]8 {, N9 u/ O: Q+ |: \$ A- Z        param[0] = (uv_min_max[0]+uv_min_max[1]) / 2; + s+ ?& A+ A! |) }
        param[1] = (uv_min_max[2]+uv_min_max[3]) / 2;
5 X0 A1 d/ t9 O8 g        theUFSession.Modl.AskFaceProps(theFace.Tag, param, p1, u1, v1, u2, v2, unit_norm, radii);
( H. G0 {+ N1 e# `2 Q  C' V; _+ t6 p6 T7 s, E8 D
        DisplayTemporaryPoint(p1);- e" D! d1 J& [5 B
        DisplayConehead(p1, unit_norm);- m7 e* X, [, M- ?% c5 P! B

. h6 T  A& K+ h9 d( ]1 H9 G+ ~        return true;$ k( |' a% e* |& x' g; q: A2 S. z7 @
    }7 ]  @, S2 q2 v; s; O; \
   
' u5 N8 t* `0 {- d: _# \% k    static void DisplayTemporaryPoint(Double[] loc)3 q) q! K- r0 ]8 g
    {
3 Y5 g& d8 B' }1 k        UFObj.DispProps color = new UFObj.DispProps();
8 |' k" e5 q0 p; o5 o5 d) l- s        color.color = 6;( t( U/ k5 M% }" p" p5 Q
        theUFSession.Disp.DisplayTemporaryPoint(Tag.Null, UFDisp.ViewType.UseWorkView,
9 `( T- E$ g4 m! |8 A& }4 w# Q" }            loc, ref color, UFDisp.PolyMarker.FilledCircle);
' ?! M! y# x( p9 p6 Z0 z0 z    }: ~( @' E3 T0 t3 v7 a1 Q
* P5 j- }' A, p9 f3 d. W3 Y
    static void DisplayConehead(Double[] loc, Double[] dir)
+ C! n! E0 {% m0 N* Q5 M# z    {
* y1 D6 y- J% i! T1 E; o( y        theUFSession.Disp.Conehead(UFConstants.UF_DISP_WORK_VIEW_ONLY, loc, dir, 0);- ~- B& ^: F& `
    }. Q8 a; A, b* B% Y% L
[/mw_shl_code]
* M/ I; \0 x& S
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

全部回复1

admin 发表于 2019-2-8 13:26:19

admin 沙发

2019-2-8 13:26:19

如果使用ufun的函数基本如下:
4 A( A4 x% [* W//获取面的uv极值) E4 V8 `  @( E& M- y' X# r. f
int UF_MODL_ask_face_uv_minmax
/ T" |1 N/ P+ D! W2 V' f. \(
/ ~, T) P8 W2 `# p- y0 ^% d
( i1 o/ R0 k0 D$ Y5 mtag_t face_tag,
' V. g4 _& D2 t) T7 N8 f& Vdouble uv_min_max [ 4 ]
5 E! A, O+ X  c( l* [
# q3 m( W$ Z2 r& g: z3 G)
' Z! A' d, }& f. d8 }+ a2 f4 O6 p5 r
//获取位置点信息--double param [ 2 ] 的输入就是上一步的输出, s$ ^& X; i4 o" p/ w* ~# o; Q

5 U/ q  m5 x+ r9 M8 `int UF_MODL_ask_face_props; A' O1 Q+ x& w8 E' b" P1 U9 J

2 i) D& \/ f) r- |% A" I9 p(
0 i2 h" H8 c) _' ^  C7 x: u7 ktag_t face_id,
. y( t% ^& Z7 ?; Kdouble param [ 2 ] ,
( X6 I: S+ X. A8 i1 Ldouble point [ 3 ] ,
9 A0 @2 Y7 H/ ~6 j8 ^- Kdouble u1 [ 3 ] ,
4 i. J9 }( @) m( u* Ndouble v1 [ 3 ] ,
, B7 f# d9 ]. R% l% U( R# O& Zdouble u2 [ 3 ] ,
% j, U( Z2 w7 C! p7 K/ I- x9 _double v2 [ 3 ] ,
( A1 s# c) k: ydouble unit_norm [ 3 ] ,
# g* m  l3 t+ c  _) Adouble radii [ 2 ] 6 E( A. [4 y8 }* G# N

0 ^& \( J+ _0 G" n5 O! z8 W)2 P: U4 J. e- z* N

4 D1 Q( l% T+ i& z//将点输入到显示临时的函数中
. ?% U9 \; r, ?( {0 p  J& U% Z8 |/ a7 X& n' |* s
int UF_DISP_display_temporary_point
7 c6 b9 r) A7 `9 {" ^0 Q, U* d! g5 p" Q: _! P9 Q+ i1 k  S/ X% ^
(
2 {9 m/ G7 k7 a  R$ n6 wtag_t view_tag, , z4 h7 Y6 |8 n/ T/ s2 D1 ^5 |
UF_DISP_view_type_t which_views, / d9 [+ F0 V; ?- N0 U
double markerpos [ 3 ] , 4 ^" _9 r2 `; I- z/ X
UF_OBJ_disp_props_t * color,
  |! j$ ?2 x: D: e. D$ MUF_DISP_poly_marker_t marker_type
6 d, z" Z/ b7 `  g* s$ C( n
: K; h" Q. k  j4 l% C5 F)0 M) h$ W+ M6 S! U
) k5 x  x. L* _3 k# l
//显示) `. n5 ?) @1 n
  W$ Z( k# w' Z0 S
void UF_DISP_conehead9 r6 f4 n7 q) V, H8 ?
(
  x3 L& c# U' L6 e* c0 s+ g) S) o2 t) ^+ `1 k& A  B
int display_flag,
3 r9 ?1 w3 K" j5 q2 adouble coord [ 3 ] ,
9 V# O1 v0 ?' E2 c' Pdouble vector [ 3 ] ,
9 U: D  e7 k( {/ cint anchor_flag
, R, V; A3 u- u1 \% Y  ^- C+ B( g9 @9 y( n  }$ I( g
)
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

    本网站(plmhome.com)为PLM之家工业软件学习官网站

    展示的视频材料全部免费,需要高清和特殊技术支持请联系 QQ: 939801026

    PLM之家NX CAM二次开发专题模块培训报名开始啦

    我知道了