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

[已解决] 获取实体质心信息

  [复制链接]

2015-4-26 10:38:04 5893 3

西尔贝 发表于 2015-4-25 21:47:54 |阅读模式

西尔贝 楼主

2015-4-25 21:47:54

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

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

x
运行结果就是厨师换得结果好像UF_MODL_ask_mass_props_3d(bodies,1,1,3,1,2,acc_value,mass_props,statistics);没起作用一样,,怎么回事????求大师知道啊
+ W# \& I7 V* X8 M& C$ }* _, ]
4 t7 L7 ^( `) S" R2 x7 I/ I" F3 a& r7 P& d4 K
#include <stdio.h>

# G& o  t( s8 f" c' a#include "afx.h"# i' k: `  g; n& k% R! t( a
#include <iostream>5 p& d/ c! N8 {$ h
#include <uf.h>
" Q' m* I2 E" l3 C" @: H; h/ S; E8 P#include "uf_part.h"
/ K/ h1 J, }: y9 G+ x' E9 l( q, j, X#include <uf_attr.h>" d  w6 c+ Z# O2 [6 t9 Z' F
#include <uf_ui.h>
. e2 t! H" z6 S' Q- u#include <uf_obj.h>
6 e2 V+ `4 H3 k0 d  e; _' v#include "uf_modl.h"0 y; p1 m) Y6 h/ F5 P2 l
#include "uf_weight.h"
  h2 ~* l+ \6 H" v#include "uf_modl_types.h "+ T) R; P$ c! L; v+ M  b; \
#include "stdafx.h"5 h/ z# s5 f5 U3 o5 |# x! [& m" t+ r
) V. h  {  s+ w9 G1 M* V) u! ^
3 L! P3 P" ]9 i1 t2 ]
using namespace std;: F+ g2 e+ N0 x/ B! X) s
5 u' P% B1 K% ]9 D, |

0 F% p; L+ B- e% E# N9 d- b3 q8 F& Q# C& r
9 g. _7 }( c5 y. ]. j4 ~

+ d: l3 Z+ C" I3 V1 D7 p" K% b  E; F& t  ^6 |( Q4 k
int main()
( ]! N; L8 @' r- L2 V{+ M8 v8 B1 W3 k- |: Q6 ?
int                    nReTCode = 0;
9 ~3 K9 r: Y7 E9 N. K9 n6 nint                    rcode;9 D+ e' e1 n5 ?& H# n
    CString                partName = "e:\\a.prt";  //此处为创建block的全路径名
9 l7 m, j& E" e+ }7 d& s9 C, E- X! rtag_t                  partTag = NULL_TAG;- M! }8 l; i/ }/ h5 H
tag_t                  attrTag = NULL_TAG;
; k) j% K, Q/ S- E3 V8 B6 I3 `tag_t                  obj1 = NULL_TAG;* H6 |% }/ _6 K" [1 J2 f5 o. i5 e
UF_PART_load_status_t  error_status;. G, K0 H2 j7 B5 N8 B: c% ]( ?$ O7 I

/ k$ H6 D) \) C9 P; F1 Q: I) t9 q
// initialize UG and print and error on failure
- w  u, k+ _; D& `: i2 qrcode = UF_initialize();9 D- q: u  M7 w; e9 P( @" c0 G  j& h5 o
' R1 W$ S7 J6 [+ _/ t

1 U5 x* |5 ]% D+ \2 O0 y) A: Vif ( rcode )2 r% p: H+ n- J! l) k
{0 V" O0 J' H; k( C* S" t
// TODO: change error code to suit your needs' ?7 ]: C  |* D8 Z+ U9 Y# T- z
cerr << _T("Fatal Error: UG initialization failed") << endl;' K* j4 T: v5 l9 J0 e
nRetCode = 1;
' h" \% p0 O1 w}
) P; e% S0 w9 b* w0 C2 f" `/ b* felse( i1 C0 `* q- y9 {6 J
{
$ e/ p; O& s6 h3 W: D- S  n4 m7 t. \// TODO: code your application's behavior here.
& o! w2 ^1 b; ^9 {        //把部件载入内存
5 y9 d2 V  C2 n: }  N& \; dUF_PART_open_quiet((char *)(LPCTSTR)  partName,
+ R1 C  S5 R# T" j; i) B                                             &partTag, - P; d' \! P$ e& f; `3 I
                                             &error_status);  
% a0 P4 ?' I9 ^: N- a7 k6 }
) W, G* I' Y. y& f8 S8 r0 @0 o  W9 {# o! t
//得到对象标识
/ E( Z1 x' x2 h4 U/ [( r/ C        UF_OBJ_cycle_objs_in_part( partTag, UF_feature_type, &obj1 ); 6 w' }# Z! H) B9 S. j- k$ s
1 x, n; F) {2 |" c5 I

8 D; t- X% f2 \//使用这个函数把部件做为工作部件
$ j4 ?5 M9 h3 [: T. U  N5 Z$ Btag_t body;5 d8 P( D* O# t0 D" L8 ?
  body=UF_PART_set_display_part(partTag);" ~( Q- }4 D. L0 M8 Z
tag_t  bodies[1];
! u0 x+ q1 c) g9 abodies[0]=body;
" z5 H$ `* c( e- y5 C+ Kdouble acc_value[11];2 D; t3 x' v/ g8 o
double mass_props[47];- G9 S) w) Q% A6 F7 l1 g. Z
double statistics[13];3 @4 D' ]  U9 H$ m' ], x
UF_MODL_ask_mass_props_3d(bodies,1,1,3,1,2,acc_value,mass_props,statistics);
4 P4 @  E  P" q! Q+ E! Idouble masscenter[3]={; J1 u+ U: z1 w8 U; w6 |' s
                mass_props[3]*10,
* a0 [3 v5 u0 j                mass_props[4]*10,( m! p- ?. F' |; K3 r) U; z
                mass_props[5]*10};
7 c' v: ^2 m& V3 L  u- B% r- I, N    cout << "质心x="<<masscenter[0]<< endl;
2 K, N2 F: y: ^! R8 _% t% Rcout << "质心y="<<mass_props[4]<< endl;
' S7 C- _& Z5 d# j) ]1 Ecout << "质心z="<<mass_props[5]<< endl;+ \0 Y! I- t" s4 D- z9 @- g
cout << "密度="<<mass_props[46]<< endl;
9 W' y/ d8 O+ g; u" B* w3 V
  B  _' @8 J' k8 R1 Y1 w- v8 {3 g* g( ~$ ~# ?+ m

" O* a0 ?7 S: U3 G' H( S. V
1 s' Z. o1 l  r    UF_terminate();- @5 F  N/ z* \8 X8 Q0 z; Q3 }
}
/ c1 D6 ?* v5 g6 D* E+ V* T+ f& Y5 c1 R5 M! {2 H% T" x9 C

  J! V1 z+ o0 Y+ F% ]/ ?! W6 Qreturn nRetCode;* f4 F  L# t0 G5 r8 \; M
}
9 N+ s3 b3 T9 y, L! n
D2494_RTB}NJT6AZEH0RGA0.jpg

a.zip

33.17 KB, 下载次数: 5

上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复

使用道具 举报

全部回复3

admin 发表于 2015-4-25 22:17:05

admin 沙发

2015-4-25 22:17:05

你这完全输入的tag 就是空啊
! A6 L7 d  b4 i% U( k' g
( A# N- E$ c2 i. l你输入的body 是什么数据,没有任何输入
4 ~: g5 e0 K# |3 p$ n/ R8 m2 S7 e& Q/ ?+ F  j1 f# K- s
通过  UF_OBJ_cycle_objs_in_part( partTag, UF_feature_type, &obj1 ); 4 这个你得到的是feature的类型 也没见你用啊
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 doTeam.tech
回复 支持 反对

使用道具 举报

西尔贝 发表于 2015-4-26 10:37:27

西尔贝 板凳

2015-4-26 10:37:27

那我该怎么修改啊,,怎么才能让输入的TAG不是空的????
上海点团信息科技有限公司,承接UG NX,CATIA,CREO,Solidworks 等CAx软件,Teamcenter,3D Experience等PLM软件,工业4.0数字化软件的实施\二次开发\培训相关业务,详情QQ 939801026 Tel 18301858168 网址 www.diantuankj.com/ doTeam.tech
回复 支持 反对

使用道具 举报

西尔贝 发表于 2015-4-26 10:38:04

西尔贝 地板

2015-4-26 10:38:04

admin 发表于 2015-4-25 22:17% z7 V8 b/ L% _
你这完全输入的tag 就是空啊9 h- f* @: N9 }- ^* I; R
  \/ A& H( g0 @7 l- P
你输入的body 是什么数据,没有任何输入

. T5 [( T6 V" g& G
8 e; H5 ~  w& G0 n4 C- @0 I那我该怎么修改啊,,怎么才能让输入的TAG不是空的????
上海点团信息科技有限公司,承接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二次开发专题模块培训报名开始啦

    我知道了