iCAx开思工具箱

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 24233|回复: 8
打印 上一主题 下一主题

【求助】关于装配,源码寻求错误

[复制链接]
跳转到指定楼层
楼主
发表于 2004-7-12 16:00:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册登录,享用更多网站功能!

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

x
我想做装配方面的,可是下列代码执行正确,却不见装配
  //打开第一个零件
  tag_t p_part = NULL_TAG;
  
  p_part = UF_open_part();
  
  //获得第一个零件的第一个平面
  tag_t first_first_plane;
  int first_first_type;
  
  char *message = "请选择第一个零件的第一个平面";
  
  UF_UI_selection_options_t opts;  
  UF_UI_mask_t mask;  
  int response;  
  tag_t view;  
  opts.other_options=0;  
  opts.reserved=NULL;  
  opts.num_mask_triples=1;  
  opts.mask_triples=[$mask]  
  opts.mask_triples->object_type = UF_face_type;//UF_face_type; UF_edge_type  
  opts.mask_triples->object_subtype=UF_all_subtype;//UF_all_subtype;  
  opts.mask_triples->solid_type=UF_UI_SEL_FEATURE_ANY_FACE ;//UF_UI_SEL_FEATURE_ANY_EDGE UF_UI_SEL_FEATURE_ANY_FACE;  
  opts.scope=UF_UI_SEL_SCOPE_ANY_IN_ASSEMBLY;//;  
  double cursor[3];
  
  double point[3];  
  double dir[3];  
  double box[6];  
  double radius;  
  double rad_data;  
  int norm_dir;  
  
  int irc = 0;
  do{
    irc=UF_UI_select_single(message, [$opts, &response, &first_first_plane, cursor, &view)]  
    if(irc == 0)
    {
      //irc = UF_MODL_ask_face_type(first_first_plane,[$first_first_type)]
      irc = UF_MODL_ask_face_data(first_first_plane,[$first_first_type,point,dir,box,&radius,&rad_data,&norm_dir)]  
      if(first_first_type == 22)
        AfxMessageBox("第一个零件的第一个平面选择成功");
      else
        UF_DISP_set_highlight(first_first_plane,0);  
      
    }
  }while(first_first_type != 22);
  
  
  //打开第二个零件
  tag_t c_part = NULL_TAG;
  
  CString child_part_name;
  child_part_name = Get_part_name();//得到文件名
  
  char *refset_name=NULL;  
  char instance_name[]="temp";//
  double origin[3]={0,0,0};  
    double csys_matrix[9]={1,0,0,0,1,0,0,0,1};  
  
  int layer=0;  
    tag_t instance;  
    UF_PART_load_status_t error_status;
  
  int reAss = 0;
  reAss = UF_ASSEM_add_part_to_assembly(p_part,child_part_name,refset_name,instance_name,  
       origin,csys_matrix,layer,[$instance,&error_status)]  
  
    c_part=UF_PART_ask_part_tag((LPSTR)(LPCTSTR)child_part_name);  
  
  //获得第二个零件的第一个平面
  tag_t second_first_plane;
  int second_first_type;
  
  message = "请选择第二个零件的第一个平面";
  do{
    irc=UF_UI_select_single(message, [$opts, &response, &second_first_plane, cursor, &view)]  
    if(irc == 0)
    {
      irc = UF_MODL_ask_face_type(second_first_plane,[$second_first_type)]
      if(second_first_type == first_first_type)
        AfxMessageBox("第二个零件的第一个平面选择成功");
      else
      {
        AfxMessageBox("请选择另一个平面");  
        UF_DISP_set_highlight(second_first_plane,0);  
      }
      
    }
  }while(!(second_first_type == first_first_type[$&response==5))]
    if(response!=5)  
    {  
       AfxMessageBox("不能选择平面");  
       UF_terminate();  
       return;  
    }  
  
  tag_t *from_part_occ;
  irc = UF_ASSEM_ask_occs_of_part(p_part,c_part,[$from_part_occ)]  
  tag_t from_part_ins=UF_ASSEM_ask_inst_of_part_occ(*from_part_occ);
    //char part_name[132+1];  
    double transform[4][4];
  
    //irc = UF_ASSEM_ask_component_data(*from_part_occ,part_name,refset_name,instance_name,origin,csys_matrix,transform);  
  
  
    tag_t to_part_occ;      
    to_part_occ = UF_ASSEM_ask_root_part_occ(p_part);  
  tag_t to_part_ins=UF_ASSEM_ask_inst_of_part_occ(to_part_occ);  
  
    //irc = UF_ASSEM_ask_component_data(to_part_occ,part_name,refset_name,instance_name,origin,csys_matrix,transform);  
  
     UF_ASSEM_mating_condition_t ftf;  
     UF_ASSEM_init_mc([$ftf)]  
     ftf.mated_object=from_part_ins;  
     ftf.part_occurrence=to_part_occ;  
     ftf.name=NULL;  
     ftf.user_name=FALSE;  
     ftf.constraints[0].from_status=UF_ASSEM_ok;  
     ftf.constraints[0].to_status=UF_ASSEM_ok;  
     ftf.constraints[0].mate_type=UF_ASSEM_v16_mate;  
     ftf.constraints[0].from_type=UF_ASSEM_planar_face;//; second_first_type
     ftf.constraints[0].to_type=UF_ASSEM_planar_face;//;first_first_type  
     ftf.constraints[0].from=second_first_plane;  
     ftf.constraints[0].from_part_occ=*from_part_occ;  
     ftf.constraints[0].to=first_first_plane;  
     ftf.constraints[0].to_part_occ=to_part_occ;  
     ftf.constraints[0].offset=NULL_TAG;  
     ftf.constraints[0].name="face to face";  
     ftf.constraints[0].user_name=TRUE;  
     ftf.num_constraints=1;  
     ftf.suppressed=FALSE;  
  
   UF_ASSEM_mc_status_t status;  
     UF_ASSEM_mc_structure_state_t struct_status;  
     UF_ASSEM_dof_t dof;  
     int ret=UF_ASSEM_solve_mc([$ftf,&status,&dof,transform)]  
   char   strmessage[133];
   if (ret != 0)
    UF_get_fail_message(ret,strmessage);  
     if(ret==0||status==UF_ASSEM_mc_solved)  
     {  
       ret=UF_ASSEM_apply_mc_data([$ftf,&struct_status,&status)]  
     UF_DISP_refresh();  
       ret = UF_MODL_update();
  
     UF_DISP_refresh();  
     if (ret ==0)
        AfxMessageBox("成功!");  
     }  
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 支持支持
沙发
发表于 2004-7-12 16:36:20 | 只看该作者

马上注册登录,享用更多网站功能!

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

x
板凳
发表于 2004-7-13 15:17:54 | 只看该作者

马上注册登录,享用更多网站功能!

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

x
地板
 楼主| 发表于 2004-7-13 19:00:12 | 只看该作者

马上注册登录,享用更多网站功能!

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

x
5
发表于 2004-7-13 19:14:11 | 只看该作者

马上注册登录,享用更多网站功能!

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

x
6
 楼主| 发表于 2004-7-13 22:47:22 | 只看该作者

马上注册登录,享用更多网站功能!

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

x
7
发表于 2004-7-14 10:26:51 | 只看该作者

马上注册登录,享用更多网站功能!

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

x
8
 楼主| 发表于 2004-7-22 14:40:53 | 只看该作者

马上注册登录,享用更多网站功能!

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

x
9
 楼主| 发表于 2004-8-8 10:05:53 | 只看该作者

马上注册登录,享用更多网站功能!

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

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

本版积分规则

手板模型制作,在线3D打印服务

QQ|小黑屋|手机版|开思工具箱 CAD工具箱_CAM工具箱  

GMT+8, 2024-12-24 04:21 , Processed in 0.016906 second(s), 8 queries , Gzip On, Redis On.

Powered by Discuz! X3.3

© 2002-2024 www.iCAx.org

快速回复 返回顶部 返回列表