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

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

[复制链接]

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

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

admin 楼主

2019-2-8 12:58:52

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

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

x
, _5 w- S( {" S' [( B

' H1 R6 g4 v2 A6 O$ w经常能用的到,通过选择面,显示临时法线方向和点!6 B4 [" x* H/ s# L7 K; ?

$ L$ Z3 m/ x9 w, c8 J: C8 v0 p4 w
2 v- u+ Z9 y& p5 u! x[mw_shl_code=cpp,true]  static bool DisplayNormal(Face theFace)
: y& j  [4 i6 g    {3 o5 U$ Y1 K: U+ G0 X' ~
        double[] param = new double[2];/ y, {1 X5 A$ X2 ?
        double[] p1 = new double[3];
6 q8 {% K$ l3 o# [  W        double[] u1 = new double[3];' l; d: E' P5 |+ q* T  |8 \
        double[] v1 = new double[3];
% j2 }+ R& s5 z3 n% l5 P! f' C        double[] u2 = new double[3];
  G! c0 i1 M2 u* E: e        double[] v2 = new double[3];
" T- s8 K# v$ d# u9 `9 Q, W        double[] unit_norm = new double[3];, X6 ~% y! Z% o; e  |# r6 W; Y, q
        double[] radii = new double[2];
! C" w; u. W/ o( |/ D        double[] uv_min_max = new double[4];- r# f8 q. \. {# }1 y% [( t' w
3 O% G: y" M: a" \" i( i) {- {6 T
        theUFSession.Modl.AskFaceUvMinmax(theFace.Tag, uv_min_max);
. O7 |8 |- ]3 i        param[0] = (uv_min_max[0]+uv_min_max[1]) / 2; 9 r$ Q' x: @# k% y" ^) |: t) {
        param[1] = (uv_min_max[2]+uv_min_max[3]) / 2;
9 _$ Q! k- @# g; G& s; C& D- w- B        theUFSession.Modl.AskFaceProps(theFace.Tag, param, p1, u1, v1, u2, v2, unit_norm, radii);% W% l# ~8 k1 b( Z! W+ u( T' X. _8 ~

' R+ x6 x6 S% F7 f0 {. \5 {  v        DisplayTemporaryPoint(p1);. }9 O5 |1 V9 S: V% m
        DisplayConehead(p1, unit_norm);" l0 h* Q. O! ], l' V  T) _- r

; C5 I; L0 w, u" t( S  d5 j" D        return true;/ f9 m/ v0 l& C" |% o& m- a1 g) Q# q
    }/ w, O0 x7 S8 h. j0 B8 v) u
    ) \' m6 e7 j) y$ c5 q
    static void DisplayTemporaryPoint(Double[] loc): Q9 h; Y5 I) @6 a4 |( s
    {
! R5 U2 @. w/ w        UFObj.DispProps color = new UFObj.DispProps();$ u& I/ _, O) V2 [. [, H' V
        color.color = 6;0 t* L3 s9 _; _8 \% @  ]
        theUFSession.Disp.DisplayTemporaryPoint(Tag.Null, UFDisp.ViewType.UseWorkView, 7 s5 b. m4 @* Q, X0 y
            loc, ref color, UFDisp.PolyMarker.FilledCircle);2 T: k  T  T; i& D$ ?' U0 ?' m
    }
# ~# u* e. O- ]6 i2 p' \2 l4 d- p; m$ H2 Q2 m1 v4 X1 ~
    static void DisplayConehead(Double[] loc, Double[] dir)) P1 f( C2 b; W" N, |- c
    {
8 C; |8 `( a. J        theUFSession.Disp.Conehead(UFConstants.UF_DISP_WORK_VIEW_ONLY, loc, dir, 0);3 n' |: B3 f1 X% g
    }" N* c0 z9 P& y
[/mw_shl_code]
3 x' w  @8 B& C1 G& M
上海点团信息科技有限公司,承接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的函数基本如下:& u3 O* P: K; [& \' {, g% m2 q, O
//获取面的uv极值
/ @2 I, _7 J0 |2 bint UF_MODL_ask_face_uv_minmax* J. }" u4 k# h- S& o- e
(
: N! ~% ]4 v3 V8 e3 ^& A  {/ U  T. A, h5 i! s% K+ v, N
tag_t face_tag, ) p3 Y. B7 G! I
double uv_min_max [ 4 ] + y; }% E# q- P, S  U4 |5 j% X% \
+ p, e* R" j8 O- s3 C$ l
)" l7 m" g3 k/ [4 c$ [, t: g

/ }/ O1 E- x  V4 J* J//获取位置点信息--double param [ 2 ] 的输入就是上一步的输出
; L) [% P  J/ Y$ x' o
/ `( @, i& Z0 u" C9 |int UF_MODL_ask_face_props
6 Q% k( o; \- B
: e" W1 ?: G$ }# A; P4 ](/ h- C  A& ^$ T8 |, w9 j3 L
tag_t face_id,
7 z. U" b0 c; y7 f3 t* adouble param [ 2 ] , - |( i+ l+ K4 S; ]. m7 s
double point [ 3 ] , 4 y( {# a$ e9 z( m. \% J
double u1 [ 3 ] , # `8 v9 J# h, K& ~8 g
double v1 [ 3 ] ,
. ]$ ~, t8 }5 K% a/ ]double u2 [ 3 ] ,   X: D8 I: L! A
double v2 [ 3 ] ,
; i' Q, ?6 {! a4 Z1 S4 w7 odouble unit_norm [ 3 ] , ; q, ~6 J: A" U7 P* m: M9 q
double radii [ 2 ] 5 ?, w" e/ a: Y" p
4 p2 p4 c  o1 X2 W5 }; c8 d
)
3 w5 i) [1 K' j3 i/ y3 A& C  b
//将点输入到显示临时的函数中2 l4 g' h2 {' i2 ^4 K5 Q' v4 ?

- I/ t5 s5 M# j$ k' ^8 B9 g  vint UF_DISP_display_temporary_point4 Q9 P6 _, f+ G& I$ m9 |' L

% h9 f: k8 _8 v: Y1 u0 f(9 F2 O2 t( g: x4 W; L/ W
tag_t view_tag, $ z$ `  v0 ]6 A7 g! e
UF_DISP_view_type_t which_views, * W4 r$ F/ m" Z- x5 n; G0 D
double markerpos [ 3 ] , ; m' q5 V( Z& K* ~+ x7 Y% S$ D3 Z
UF_OBJ_disp_props_t * color, . f. T) E6 f$ W
UF_DISP_poly_marker_t marker_type
7 ]; o0 t) [9 _5 H5 c" l0 ~$ f6 u" {) F: N% U5 ]) q
)$ A6 z' Q4 ]  M' ?1 b( a( @% @
' n) Z! F; \! ~
//显示" i' ?6 l5 }$ b. M) x2 Q
8 \3 ^* ^- v  p+ f/ L/ |/ Y
void UF_DISP_conehead2 y( k0 g& Q$ u$ B) c2 s
(
2 z7 P/ w' C3 k7 C* S9 s2 w9 v5 h+ \" {! Y0 i4 y* B0 N- I; J
int display_flag, + n8 [$ b0 W# J2 D4 L/ p  g. W
double coord [ 3 ] ,
: z$ V  O1 k7 f- y5 M: \3 idouble vector [ 3 ] , , L6 E4 z- P0 _
int anchor_flag
6 H5 O( X# y; d! B/ c
% P: m1 R) G$ U+ F) l( E+ s- V8 ])
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了