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

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

[复制链接]

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

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

admin 楼主

2019-2-8 12:58:52

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

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

x

" u* e5 |# e, B+ Z2 P7 R
. {+ [7 u! x  x+ n! t0 |0 M2 x经常能用的到,通过选择面,显示临时法线方向和点!
7 Z# u, X# u7 g% d/ B5 e- T: G+ @. [& Y1 y9 U* z: o
( L  i4 F9 G2 Y5 n  a1 s4 x
[mw_shl_code=cpp,true]  static bool DisplayNormal(Face theFace)
: |4 N" l% c) d- G# R' t0 {% d    {4 D( ?) @" |, j  k7 _
        double[] param = new double[2];- R) b- o1 q+ @& \: q
        double[] p1 = new double[3];0 j3 i7 N2 n* K: C7 m  I8 J- T
        double[] u1 = new double[3];
% n- h$ F2 H( s) F' @        double[] v1 = new double[3];+ ?# V) ^3 P0 h1 u$ O, N
        double[] u2 = new double[3];& F' k3 L% E5 j9 N
        double[] v2 = new double[3];4 r/ Q0 B5 f3 c6 h* [' T
        double[] unit_norm = new double[3];
( O# S/ a* n+ a  g% K0 B2 C        double[] radii = new double[2];
  d1 e$ m8 \( O% Y, s+ S) g        double[] uv_min_max = new double[4];
" ?7 U7 O3 Y7 B) {- r$ }+ I+ A+ Q( D+ C+ `: m
        theUFSession.Modl.AskFaceUvMinmax(theFace.Tag, uv_min_max);7 i& k; ~. c5 W" g0 l
        param[0] = (uv_min_max[0]+uv_min_max[1]) / 2;
# a& M5 \7 O% Y5 ~  o3 @        param[1] = (uv_min_max[2]+uv_min_max[3]) / 2; 6 E% `: i) H! h6 L; a, K: ^
        theUFSession.Modl.AskFaceProps(theFace.Tag, param, p1, u1, v1, u2, v2, unit_norm, radii);
+ [! b9 {( N  @6 g& B6 H' I' @; _5 z: k: d4 \! }
        DisplayTemporaryPoint(p1);
: e% @9 E8 d$ F' u5 q/ f& c        DisplayConehead(p1, unit_norm);
/ ?( V( a' p, {2 y
2 z+ t: B0 D3 L        return true;4 O5 _- x7 Q: k) h; U( g7 G2 c, G; x" L
    }
7 \5 G; G( J! o; U) d   
: j9 f. I' V& N9 ?    static void DisplayTemporaryPoint(Double[] loc), S; ]) R# X: Q6 h
    {
( K( o5 z% S) O5 Q! M9 V$ r: Z        UFObj.DispProps color = new UFObj.DispProps();! X/ Z% m8 T1 H' u
        color.color = 6;
4 ]1 t4 A" P" j1 N+ I; V        theUFSession.Disp.DisplayTemporaryPoint(Tag.Null, UFDisp.ViewType.UseWorkView,
  i' \6 X+ a0 r: {+ Z- x" L            loc, ref color, UFDisp.PolyMarker.FilledCircle);/ ]' d9 }+ F' k. B
    }
$ ~" Q! H8 Z1 O8 S. C* D4 i2 ?; B( K( i# R% V7 E$ h$ i
    static void DisplayConehead(Double[] loc, Double[] dir), }- b: O. J/ I; h
    {7 r/ f" u/ P. {1 j
        theUFSession.Disp.Conehead(UFConstants.UF_DISP_WORK_VIEW_ONLY, loc, dir, 0);
/ w8 `' y/ l8 T1 n$ O' O    }( A2 `, |* |$ h
[/mw_shl_code]5 C5 m# M* R; K. l: T+ m, b& T
上海点团信息科技有限公司,承接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的函数基本如下:
9 h% m6 I. v* _" n//获取面的uv极值" A  o5 `+ C; p' l+ G5 @& Y
int UF_MODL_ask_face_uv_minmax
/ F- Y/ w; g) d4 [* ^9 ^(( y" A1 R2 |& M
2 x( c; `0 u' E9 o2 p+ T  G
tag_t face_tag,
! ?- `/ p! H* X8 d# _9 i2 W$ F# Ydouble uv_min_max [ 4 ]
) C' R: m' S2 O0 d
  l6 a: ]- @! D5 h( h): i! K6 C) ^: W! P1 [& ~
) r. h) i0 k$ r# G
//获取位置点信息--double param [ 2 ] 的输入就是上一步的输出# }2 b9 h% X9 q/ R1 L
& P: H% I9 y9 U# f- R
int UF_MODL_ask_face_props5 N+ d3 i. b+ y+ T- [" ]- P

% G, F% m0 h* w$ @" p(, [5 T+ S. D. h
tag_t face_id, ' n( l% s$ \  x7 l
double param [ 2 ] , % L' T2 ~8 ^( Z* D0 V$ q0 p
double point [ 3 ] , 1 X; c" Y# y4 A* j" s
double u1 [ 3 ] ,
7 l. \0 B- t9 [4 M2 d4 q7 f- |double v1 [ 3 ] ,
0 M  T4 W9 Z: ~8 sdouble u2 [ 3 ] ,
0 K% b; r: m6 [1 Z1 V: N* @5 tdouble v2 [ 3 ] ,
+ h; Q6 i; E; G, a8 K+ N2 Z- t" D; Gdouble unit_norm [ 3 ] , / [6 d- o7 N  y# J
double radii [ 2 ] 5 ~1 y# t4 l% S3 i0 V$ F; ^

5 ^/ _+ H0 |2 j)+ i* |# s3 v+ W- [3 H

& K7 f% Q4 t" p0 S+ ]//将点输入到显示临时的函数中
% M% J3 r( X7 E3 G
6 Z" ~  h+ t* @+ D1 k* ^int UF_DISP_display_temporary_point
" [1 |7 U9 M% H* k4 s/ @5 {6 x% ^9 w: U# _5 O* V
(
8 x! |4 `! v; U. k6 D! l3 Atag_t view_tag, ; l; Q+ ^, ^* p4 d1 V# e
UF_DISP_view_type_t which_views,
$ ^6 F+ G) u% W! `: xdouble markerpos [ 3 ] , - f7 G# v6 @& C& ]+ p1 d
UF_OBJ_disp_props_t * color, " g' J2 T7 [( {
UF_DISP_poly_marker_t marker_type 4 s: S/ g, P# j( w. P

( V% A" ]( \: l! p; ~2 g4 Z  `)" ?- _; T3 Q/ C; Z
! i  j1 y& C; Z2 t5 t
//显示8 @& N% t" O( |' @4 k, ^2 ^
$ y; Z3 ~/ h$ Q  J4 Z7 k: I% D/ U1 P
void UF_DISP_conehead/ ^" J" w0 z5 d; I
(
5 Y+ R: ]! s4 V- \+ _' a  s; i; Q' r- E7 ?/ V6 q& `' e/ r
int display_flag,   y* y/ }8 ^3 c4 B$ M2 W6 ]
double coord [ 3 ] , , I- ?% B: p: w' G7 O. z
double vector [ 3 ] ,
: q: c+ s& K; V: Pint anchor_flag
! w9 @5 J( w2 L; E. S! m* g! K1 q" Z7 K( B. l7 w: S
)
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了