PLM之家PLMHome-工业软件与AI结合践行者

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

  [复制链接]

2015-4-26 10:38:04 5959 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);没起作用一样,,怎么回事????求大师知道啊' S: E7 |0 q- f1 J' q
  G1 y! |/ ?6 w
" |1 B0 T* f* S. ]8 u, {, P
#include <stdio.h>
* O% ?! q+ J! _
#include "afx.h"
, q6 @' ^# i# y1 s#include <iostream>
6 T; l! b" ]0 o#include <uf.h>
% D  E: e% T( t$ n$ l( x#include "uf_part.h"
* V' J" p5 w# ]! L- L7 q7 B#include <uf_attr.h>
* {$ ?8 `( D% M2 W  A7 O#include <uf_ui.h>6 V7 e; m6 y) l- o( ]9 ~  j) W
#include <uf_obj.h>
/ |. ~4 `5 f6 b1 Q#include "uf_modl.h"
/ U; ?3 S* g5 G; G" n$ y5 q  s#include "uf_weight.h"  q5 V- X; ~' L. f9 K, {
#include "uf_modl_types.h ". N! {- t6 O$ b: p& ^8 {0 o! o8 F1 h5 J
#include "stdafx.h". L3 V% C3 T& D% \. M, v1 X8 f
& m$ e0 t" Q! M- ]  O2 r

4 ?6 `$ Q. P9 A. F5 Nusing namespace std;
# Z+ s- s; H7 ]% s5 i: i
& c& c. m. o0 S5 l3 H# `$ e+ o- |$ `
% Z# A+ L: V! y+ B$ g% m+ j3 c% V8 q3 x1 t

0 d7 k, s) {; e" I6 p% [2 ~! h3 i8 ~9 v! U% W

/ x/ N' b6 m+ i) E0 zint main()
& Y; w& P" R% d2 k, Z: P9 `, q, H{; y+ j, J8 F$ |$ n4 [) T5 J# U  u
int                    nReTCode = 0;
' b! A5 @$ n0 \! C+ V' S, Lint                    rcode;- A, e& ~# n- [" f  W5 w
    CString                partName = "e:\\a.prt";  //此处为创建block的全路径名
" ]3 G' q+ ~; `5 X8 ctag_t                  partTag = NULL_TAG;
0 Q, N3 M6 ^) v8 R* q% b4 n. S( Ztag_t                  attrTag = NULL_TAG;; r  \7 {# A& t. {5 L2 t
tag_t                  obj1 = NULL_TAG;
7 F* t: @5 n9 I5 Y- u9 Q+ hUF_PART_load_status_t  error_status;
% c+ s% E9 \  J/ U* n# M/ i  v9 G* k
: L% ~7 l6 g. u6 w6 r' c0 @9 P& y0 Q) `8 I
// initialize UG and print and error on failure1 x8 R/ E4 x# |+ a
rcode = UF_initialize();
8 L% `0 @) d9 h) ~. t
9 }  E( c& M6 Q, P( v( T9 q6 W9 D9 Q+ K$ \$ C$ c* \1 [
if ( rcode )
6 h; Z) W. v6 G# N2 W- S{. I8 X6 j0 J' ]) G! _5 e; `+ r- V
// TODO: change error code to suit your needs. R8 n. U, T, C; f6 c+ [8 {# k7 [
cerr << _T("Fatal Error: UG initialization failed") << endl;: u" I7 ~* R6 K( t
nRetCode = 1;6 L' \0 u/ _8 S4 c/ M5 @
}4 }% R( U, D  Q( Z2 F1 |9 S; {
else! r% W% _4 @5 t. c" J: G# V5 Y
{. l  r+ w& `  C' `! [' Q
// TODO: code your application's behavior here.
" \3 [0 R& `/ f7 g        //把部件载入内存
) e" F2 b* S" m; U9 \, fUF_PART_open_quiet((char *)(LPCTSTR)  partName,
6 a" |6 B# R0 r( X+ ]7 Y                                             &partTag, 3 e1 I; j3 v7 x# d3 W
                                             &error_status);  % z8 ^9 |$ N4 k6 I' l( N

( k1 T6 ^+ h8 g9 I! e0 N. P3 [' j
//得到对象标识
, c" E/ e6 {2 n! x4 {4 o! Y1 C& `        UF_OBJ_cycle_objs_in_part( partTag, UF_feature_type, &obj1 ); " O5 ^$ |8 D3 Q2 i' d# w
* b+ J: }) N3 l+ A
& M6 ?% S) J/ M2 G* S
//使用这个函数把部件做为工作部件0 g" E5 F  I; F4 P, c
tag_t body;6 T) S7 r9 |. l8 w# ~
  body=UF_PART_set_display_part(partTag);
2 {9 z5 P7 }: g% ~- Z: c, x& Qtag_t  bodies[1];
: b/ K2 P, m6 Ebodies[0]=body;) i0 B1 X4 W0 n2 p' Y8 p8 x7 L
double acc_value[11];2 x1 b6 t8 `. k2 U7 ?
double mass_props[47];
9 b1 }: T9 g4 Udouble statistics[13];
( W1 P, u5 }) s# c2 ~UF_MODL_ask_mass_props_3d(bodies,1,1,3,1,2,acc_value,mass_props,statistics);
! `# ]' A, [2 [! sdouble masscenter[3]={5 r2 G% r, n; _% H6 q* P* N. J, D
                mass_props[3]*10,$ B3 q6 k! V* w2 e/ ^3 F: h
                mass_props[4]*10,5 a3 b6 ^; \+ Z% m6 i8 Z0 M
                mass_props[5]*10};2 ^9 `4 Q% f# a- C: P* I
    cout << "质心x="<<masscenter[0]<< endl;* z9 C' g2 I6 L5 _" e
cout << "质心y="<<mass_props[4]<< endl;
% V& n& k' x. t9 h9 R( l, Acout << "质心z="<<mass_props[5]<< endl;& R% v' ]/ e5 X7 Z$ M
cout << "密度="<<mass_props[46]<< endl;1 _: f. o# k; Z

2 d, n* ?4 N# P5 q0 a! \/ Y/ t- l) Q

" D! S7 n9 c* z* m3 R' Q) e2 p& z) X- ~6 C' s! m
    UF_terminate();4 K2 W, p- ]2 R% ?3 V! {
}: `" V" N5 {% S0 N& b, u

( E5 U5 J0 a$ f& p! r) @
$ G# O5 d' j+ I8 treturn nRetCode;" e$ ^! U; \8 W' e3 A3 z3 v& P- w
}
( N3 r9 d, J$ j/ a+ ~2 B: i
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 就是空啊1 {: F+ K! X( h4 ?2 g# [

1 m( E1 g, C- V. T, I9 q2 J你输入的body 是什么数据,没有任何输入
$ M4 ]9 [* Y  {- t3 B
2 S6 O. a5 G4 y+ |) 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
) v  J0 j: J. m) e' T7 b7 n4 A你这完全输入的tag 就是空啊
# a+ k" S, d0 N* p+ Q9 x% W
% p; U+ }8 f" N2 x" M3 ]; j你输入的body 是什么数据,没有任何输入
6 O: b, k( l% W( q7 M  H# i9 w1 v

2 D* e: z, X$ w2 f* \! [0 J那我该怎么修改啊,,怎么才能让输入的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二次开发专题模块培训报名开始啦

    我知道了