znl 发表于 2018-10-16 09:56:58

UG二次开发ugupdate更新模型并输出x_t

本帖最后由 znl 于 2018-10-16 09:57 编辑

小弟在网上找到c++代码实现ug模型自动根据参数文件更新,并输出x_t文件。模型更新部分没有问题,在输出x_t文件时,含有片体的模型都会报Non-body Did input。有什么办法解决吗?或者有大神能指导编一个由prt输出x_t的小程序吗,一定要能输出片体!!!!这是我找到的代码:
#include <iostream>
#include <string>
#include <uf.h>
#include <uf_modl.h>
#include <uf_ps.h>
#include <uf_obj.h>
#include <uf_assem.h>
#include <uf_part.h>
#include <uf_modl_expressions.h>
using namespace std;
/*
功能:
   用exp文件更新prt文件文,并将prt文件另存为x_t文件
调用方法:
    system("you.prt   you.exp   you.x_t")
    createprocess("you.prt","you.exp   d:\\you.x_t"...)
注意:
    文件名一定要写全,在导出时会自动删除旧的文件否则可能
    因为文件已经存在而导致导出x_t文件失败。

                                 san,nuaa,202
                    visualsan@yahoo.cn
                                 2011.11.13
*/
intprt_save_as_xt(tag_t,string ps);
//引入lib文件,因人而异
#pragmacomment(lib,"D:\\Program Files (x86)\\UGS\\NX 5.0\\UGOPEN\\libufun.lib")
#define VISUALSAN_NUAA_202_RUN(x)\
if(0!=x)\
{\
    char msg;\
    UF_get_fail_message( x,msg );\
    cout<<msg;\
    return -1;\
}

intmain(int argc,char **argv)
{

    //实现初始化ug api,否则其它ug函数是无法使用的
    VISUALSAN_NUAA_202_RUN( UF_initialize() );

    //文件路径
    stringprt,ep;
    stringx_t;//x_t格式文件地址

    /*参数个数检查,
    注意用system("UG_update.exe xx.prtyy.exp")调用时,
    默认第一个参数为exe地址,所以你的参数
    是第二个开始;用createprocess时,则参数和你传递的一样
    system("UG_update.exe xx.prtyy.x_t")
      argv=UG_update.exe argv=xx.prt argv=yy.expargv=yy.x_t

    createprocess("UG_update.exe","xx.prtyy.exp yy.x_t",....)
      argv=xx.prt argv=yy.exp argv=yy.x_t*/

    if( argc<3 )
    {
      cerr<<"参数个数不足";
      return-1;
    }
    //默认你是用createprocess创建线程的
    if(argc==3)
    {
      prt = argv;//prt文件
      ep= argv;//exp文件
      x_t = argv; //x_t文件
    }
    //否则是用system调用的
    else
    {
      prt = argv; //prt文件
      ep= argv; //exp文件
      x_t = argv; //x_t文件
    }

    //打开模型文件
    UF_PART_load_status_t st;
    tag_tprt_id;
    //打开prt文件
    VISUALSAN_NUAA_202_RUN( UF_PART_open( prt.c_str(), &prt_id, &st ) );
    //更新模型文件
    VISUALSAN_NUAA_202_RUN( UF_MODL_import_exp( (char*)ep.c_str() , 0) );
    //更新模型
    VISUALSAN_NUAA_202_RUN( UF_MODL_update() );
    //写入文件
    VISUALSAN_NUAA_202_RUN( UF_PART_save() );

    //另存为x_t文件
    if( -1 == prt_save_as_xt(prt_id,x_t) )
      return -1;

    //关闭prt文件
    VISUALSAN_NUAA_202_RUN( UF_PART_close(prt_id,1,1) );
    VISUALSAN_NUAA_202_RUN( UF_PART_free_load_status(&st) );
    //退出前UF_terminate调用清理
    VISUALSAN_NUAA_202_RUN( UF_terminate() );

    return 0;
}
intprt_save_as_xt(tag_t body_tag,string ps)
{
    //没有后缀名时,加上后缀名
    if( std::string::npos == ps.find( ".x_t" ))
      ps += ".x_t";
    //引用代码:Ug2Ansys.cpp李 响, 中国地质大学(北京) 2006.12.31
    uf_list_p_t body_list;
    // 获得装配树根事例root_part_occ, 当函数返回NULL_TAG时, 表明当前部件文件中没有装配(即单个部件)
    tag_t root_part_occ = UF_ASSEM_ask_root_part_occ( body_tag );
    VISUALSAN_NUAA_202_RUN( UF_MODL_create_list(&body_list) );
    // 如果是单个部件
    if(root_part_occ == NULL_TAG)
    {
      tag_t object = NULL_TAG;
      int UF_body_type;
      int type;
      int subtype;   
      do{
            VISUALSAN_NUAA_202_RUN(
                UF_OBJ_cycle_objs_in_part(body_tag, UF_solid_type, &object)
                );
            if(object != NULL_TAG)
            {
                VISUALSAN_NUAA_202_RUN(
                  UF_OBJ_ask_type_and_subtype(object, &type, &subtype)
                  );
                VISUALSAN_NUAA_202_RUN(
                  UF_MODL_ask_body_type(object, &UF_body_type)
                  );

                if(subtype != UF_solid_body_subtype)
                  continue;
                if(UF_body_type == UF_MODL_SOLID_BODY)
                {
                  VISUALSAN_NUAA_202_RUN(
                        UF_MODL_put_list_item(body_list, object)
                        );
                  break;
                }
            }
      }while(1);

    }
    //如果是装配体
    else
    {
      tag_t obj = UF_ASSEM_ask_prototype_of_occ(root_part_occ);
      tag_t object = NULL_TAG;
      int UF_body_type;
      int type;
      int subtype;
      do
      {
            VISUALSAN_NUAA_202_RUN(
                UF_OBJ_cycle_objs_in_part(body_tag, UF_solid_type, &object) );
            if(object != NULL_TAG)
            {
                VISUALSAN_NUAA_202_RUN(
                  UF_OBJ_ask_type_and_subtype(object, &type, &subtype) );
                // 判断body是否是一个Solid或Sheet
                VISUALSAN_NUAA_202_RUN(
                  UF_MODL_ask_body_type(object, &UF_body_type) );

                if(subtype != UF_solid_body_subtype)
                  continue;
                if(UF_body_type == UF_MODL_SOLID_BODY)
                {
                  // 将对象加入到链表的尾部
                  VISUALSAN_NUAA_202_RUN(
                        UF_MODL_put_list_item(body_list, object) );
                }
            }
            else
            {
                break;
            }

      }while(1);

    }

    // 如果文件存在, 先删除
    remove( ps.c_str() );
    // 创建Parasolid文件
    VISUALSAN_NUAA_202_RUN(
      UF_PS_export_data(body_list,(char*)ps.c_str() ) );
    // 删除链表
    VISUALSAN_NUAA_202_RUN(
      UF_MODL_delete_list(&body_list) );

    return 0;
}

znl 发表于 2018-10-16 16:22:09

没有人知道该怎么处理吗?

znl 发表于 2018-10-18 08:27:05

或者写一个把prt转换成parasolid的小程序

binya2000 发表于 2018-10-18 22:07:20

eugene_yao 发表于 2018-11-15 00:15:23

请问楼主的问题解决了吗?我也有类似这方面的问题想咨询一下

eugene_yao 发表于 2018-11-15 00:36:45

请问楼主问题解决了吗

yunxu 发表于 2019-9-23 09:50:24

您好,方便加个联系方式吗,我也有类似的UG二次开发问题,走投无路想请教您,我QQ1826459051,谢谢您

sustshz 发表于 2020-2-11 11:37:29

我也在寻找与isight集成的UpDATE程序,也找到与楼主相同的程序了,没法用,哪位大神能够解决这种问题啊?

sustshz 发表于 2020-2-11 11:38:08

我也遇到了此类问题,哪位大神恩能够给就解决一下啊?

binya2000 发表于 2020-2-11 20:12:05

页: [1] 2
查看完整版本: UG二次开发ugupdate更新模型并输出x_t