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

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

[复制链接]

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

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

admin 楼主

2019-2-8 12:58:52

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

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

x

5 L+ i7 N) Z- b- z0 X9 X0 d
- ?' m# k: |; O, M. u经常能用的到,通过选择面,显示临时法线方向和点!
, L3 E1 `* D. A- H9 ]! v2 k0 X  U* G

& V3 V0 p- s; J  K0 Z9 E& v" G[mw_shl_code=cpp,true]  static bool DisplayNormal(Face theFace)
$ D# G7 b0 r3 m) c8 Z8 v    {
7 x& q* I# p! Z7 o" m' V! d        double[] param = new double[2];
/ w) M* n, y: {        double[] p1 = new double[3];
, G% O5 n0 K* C! P) d! Y        double[] u1 = new double[3];+ D; v' v5 g0 [
        double[] v1 = new double[3];
# ~8 F6 C' c. R  J/ e2 ^0 W" G& J        double[] u2 = new double[3];
+ }8 E5 ?- O* ^        double[] v2 = new double[3];
- A6 N1 T7 Y2 `7 l        double[] unit_norm = new double[3];; ^9 [+ _5 l, C9 V4 }3 D) `
        double[] radii = new double[2];0 d# i7 E. O1 U& [- x% i8 s' y9 X& A/ X
        double[] uv_min_max = new double[4];
! l5 {+ N  {2 [  y& Y3 O0 ]
  i+ U2 i) y' v        theUFSession.Modl.AskFaceUvMinmax(theFace.Tag, uv_min_max);
- ~7 T- J. O/ k7 t1 s: i        param[0] = (uv_min_max[0]+uv_min_max[1]) / 2;
* L7 d6 a/ w+ x0 J+ Y( |7 |( R        param[1] = (uv_min_max[2]+uv_min_max[3]) / 2; $ E7 s" I2 U7 ~. X0 W2 @' s/ a
        theUFSession.Modl.AskFaceProps(theFace.Tag, param, p1, u1, v1, u2, v2, unit_norm, radii);* K  u7 U7 E0 n3 ?- }
1 Z: }) T7 b3 e0 F4 h
        DisplayTemporaryPoint(p1);! `( H! \' K% }6 v9 ~, ~- k+ [
        DisplayConehead(p1, unit_norm);  s' v' I. a, W% M1 v7 `' V* b
3 t# s6 v* D4 z2 b/ C0 A
        return true;
  F1 Y) V2 l1 ^    }1 r3 U% Z! F+ P: R. r2 G, s
    ; a2 d8 A( `/ l3 H
    static void DisplayTemporaryPoint(Double[] loc)0 h  N# E+ W6 w# I, |! d9 V
    {
" K* t" C0 c; a- f. Z        UFObj.DispProps color = new UFObj.DispProps();+ y' ^/ e5 Q  U
        color.color = 6;
% w, g+ ~9 j% W6 o        theUFSession.Disp.DisplayTemporaryPoint(Tag.Null, UFDisp.ViewType.UseWorkView,
+ F3 [$ ^: N7 Y5 a  _# V: A            loc, ref color, UFDisp.PolyMarker.FilledCircle);/ ?4 H3 |. F% g+ Q
    }
" w& i6 i7 [3 c- p# l2 ^: ~4 z! ~4 u" T7 _
    static void DisplayConehead(Double[] loc, Double[] dir)  G' i" A) F- k. ]2 m3 G- u: L
    {
; y, @% `1 F2 |4 e2 b  A        theUFSession.Disp.Conehead(UFConstants.UF_DISP_WORK_VIEW_ONLY, loc, dir, 0);5 \/ p4 m4 C3 e- J; I
    }
; T, U6 u3 u6 z+ W# S- C: X[/mw_shl_code]9 D( J  r( e" X& O% y  G, L# N# G
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复

使用道具 举报

全部回复1

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

admin 沙发

2019-2-8 13:26:19

如果使用ufun的函数基本如下:8 v) D9 m: q5 ^" [2 ?& L
//获取面的uv极值5 q0 z" c& p! _- D6 z
int UF_MODL_ask_face_uv_minmax4 @' K( j8 S, Z! c* w- M' y9 F4 D
(; `  m9 J3 j! a* c
2 e7 Y) e' [8 p3 d, G9 C8 b6 [, f
tag_t face_tag,
: D% G3 z# ]" Ldouble uv_min_max [ 4 ]
. x" |& F/ y, c9 h9 e5 z
& a7 T2 }. O& r)
" T# W' A: x7 T' W) d5 h/ q. [+ Y1 d# _& W3 g4 Z7 X0 S
//获取位置点信息--double param [ 2 ] 的输入就是上一步的输出8 H1 P+ Y6 z2 o/ f" x4 s" a
  \+ V0 d) z8 }- J* W
int UF_MODL_ask_face_props
" K7 w$ @2 e2 t" Q" @/ Y  q& k2 l7 E8 q2 g/ Y& u) t
(
/ n% M; j. L2 r4 f1 dtag_t face_id,
& @# ~0 T8 |+ I; t' ]/ Q- ydouble param [ 2 ] , , Q9 x/ {1 C0 G; E) u5 z5 p
double point [ 3 ] ,
; I: W+ O2 h9 Zdouble u1 [ 3 ] ,
  Y0 c& U; \$ G; Y3 L9 Odouble v1 [ 3 ] , 0 K  _& B! W, a
double u2 [ 3 ] , 7 b# b& R- j4 C
double v2 [ 3 ] ,
, J6 P6 G: v" X4 Ndouble unit_norm [ 3 ] ,
4 [. u4 U( w- }: r0 Kdouble radii [ 2 ]
) d. }. R0 k. B; W2 d/ ^0 k" ]7 Q) w
1 ^1 F! w# x' j. l# H  Q# D)$ c# D$ ]. {9 D, r

" K# c( P# n3 x" O  h4 P9 f' i//将点输入到显示临时的函数中
( i( u0 w5 T# Y3 C/ @* m
- `: o  @, h! T: Z0 `int UF_DISP_display_temporary_point
5 ^+ W! G& C+ {2 D+ Q$ L3 t7 @+ x; y8 T+ c, Y
(
% ]& s, b9 t! @/ l$ Htag_t view_tag,
4 m8 a# d# V% s# p$ W* uUF_DISP_view_type_t which_views,
0 h" o! d& q* l" M( ydouble markerpos [ 3 ] , ; C7 ~& S" ?: t9 G
UF_OBJ_disp_props_t * color,
7 m! x7 ?) C9 pUF_DISP_poly_marker_t marker_type + l9 U- S. ?" o- p  p( D
! p* R( a& R1 b; Y' l# J
)
, m" }8 q# g+ l" ~7 w2 g' Y1 Z& B  {  S2 g4 h* S. O
//显示
- t( C1 z* W) X. h2 s8 m9 q# ?6 R; a
void UF_DISP_conehead: h( e0 p# b9 J/ E: a! F: v
(- u8 t2 i; g3 h

% g' y2 [2 ]- gint display_flag,
& N" [2 z5 M3 a+ A/ j5 adouble coord [ 3 ] ,
% [! z1 q) w# U6 s; L8 Xdouble vector [ 3 ] ,
1 d0 o! h7 o4 D1 ]int anchor_flag 4 `3 @2 n7 T  f0 n
$ G4 z/ q; ]8 P: _
)
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复 支持 反对

使用道具 举报

发表回复

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

返回列表 本版积分规则

  • 发布新帖

  • 在线客服

  • 微信

  • 客户端

  • 返回顶部

  • x
    温馨提示

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

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

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

    我知道了