草庐IT

Teamcenter_NX集成开发:UF_UGMGR函数的使用

huangym1 2023-03-28 原文

最近工作中经常使用Teamcenter、NX集成开发的情况,因此在这里记录UF_UGMGR函数的使用。使用UF_UGMGR相关函数需要有Teamcenter使用经验,理解Teamcenter中文件夹、伪文件夹、零组件、零组件版本、数据集、关系、表单、命名引用等对象。

相关的可以看帮助中 Teamcenter Integration for NX的内容 及 UF_UGMGR Overview 介绍的数据模型及使用方法、注意事项。

主要操作:

1-初始化UGMGR环境成功后就可以连接到Teamcenter。

2-获取指定ID编码零组件标识和Latest Working(没记错的话应该是最新版本)版本ID。

3-UF_UGMGR相关函数使用

  1 // Mandatory UF Includes
  2 #include <uf.h>
  3 #include <uf_object_types.h>
  4 #include <uf_ugmgr.h>
  5 #include <uf_part.h>
  6 #include <uf_disp.h>
  7 #include <uf_modl.h>
  8 #include <uf_obj.h>
  9 #include <uf_assem.h>
 10 
 11 // Internal+External Includes
 12 #include <NXOpen/Annotations.hxx>
 13 #include <NXOpen/Assemblies_Component.hxx>
 14 #include <NXOpen/Assemblies_ComponentAssembly.hxx>
 15 #include <NXOpen/Body.hxx>
 16 #include <NXOpen/BodyCollection.hxx>
 17 #include <NXOpen/Face.hxx>
 18 #include <NXOpen/Line.hxx>
 19 #include <NXOpen/NXException.hxx>
 20 #include <NXOpen/NXObject.hxx>
 21 #include <NXOpen/Part.hxx>
 22 #include <NXOpen/PartCollection.hxx>
 23 #include <NXOpen/Session.hxx>
 24 
 25 #include <NXOpen/PDM_PdmSession.hxx>
 26 #include <NXOpen/PDM_SoaConnectionHandle.hxx>
 27 #include <teamcenter/soa/client/Connection.hxx>
 28 #include <teamcenter/services/core/DatamanagementService.hxx>
 29 #include <teamcenter/soa/common/Version.hxx>
 30 
 31 // Std C++ Includes
 32 #include <iostream>
 33 #include <sstream>
 34 #include <stdio.h>
 35 #include <stdlib.h>
 36 
 37 using namespace NXOpen;
 38 using namespace Teamcenter::Soa::Client;
 39 using namespace Teamcenter::Services::Core;
 40 using std::string;
 41 using std::exception;
 42 using std::stringstream;
 43 using std::endl;
 44 using std::cout;
 45 using std::cerr;
 46 
 47 static int indent_level = 0;
 48 
 49 #define CHECK( func_ ) \
 50     ifail = (func_); \
 51 if (ifail != 0) {\
 52 printf("ERROR: %s returned %d", # func_, ifail); \
 53 return ifail;}
 54 
 55 #define PRINT( content_ ) \
 56 { int ii; \
 57 for (ii = 0; ii < indent_level; ii++) \
 58 { printf("  "); } \
 59     printf content_; \
 60     printf("\n"); }
 61 
 62 static int  list_in_part(UF_UGMGR_tag_t part)
 63 {
 64     int _errCode = 0;
 65     UF_UGMGR_tag_t*  revisions;
 66     int              i, j, k;
 67     int              count;
 68     int              dep_count;
 69     int              rev_count;
 70     char**           names;
 71     char**           file_types;
 72     char**           file_names;
 73     char             part_name[MAX_FSPEC_SIZE + 1];
 74     char             revision_id[UF_UGMGR_NAME_SIZE + 1];
 75     char             part_number[UF_UGMGR_NAME_SIZE + 1];
 76     if (part == UF_UGMGR_null_tag)
 77         return -1;
 78 
 79     _errCode = UF_UGMGR_ask_part_number(part, part_number);// 获取零组件ItemID
 80     PRINT(("Part: %s", part_number));
 81     indent_level++;
 82     _errCode = UF_UGMGR_list_part_revisions(part, &rev_count, &revisions);// 获取零组件所有版本
 83     for (j = 0; j < rev_count; j++)
 84     {
 85         _errCode = UF_UGMGR_ask_part_revision_id(revisions[j], revision_id);// 获取版本ID
 86         _errCode = UF_UGMGR_encode_part_filename(part_number, revision_id, "", "", part_name);// encode文件名
 87         PRINT(("Rev.: %s - Type: %s", revision_id, "master"));
 88         indent_level++;
 89 
 90         _errCode = UF_UGMGR_ask_dependent_files(part_name, &dep_count, &names);// 获取关联文件
 91         for (k = 0; k < dep_count; k++)
 92             PRINT(("Dependent files: %s", names[k]));
 93 
 94         indent_level--;
 95         if (dep_count > 0)
 96             UF_free_string_array(dep_count, names);
 97 
 98         _errCode = UF_UGMGR_list_part_rev_files(revisions[j], &count, &file_types, &file_names);// 列出版本下数据集
 99         for (i = 0; i < count; i++)
100         {
101             _errCode = UF_UGMGR_encode_part_filename(part_number, revision_id, file_types[i], file_names[i], part_name);// 根据ItemID、版本、文件类型、文件名encode成新的文件名
102             PRINT(("Rev.: %s - Type: %s, Name: %s", revision_id, file_types[i], file_names[i]));
103             indent_level++;
104             _errCode = UF_UGMGR_ask_dependent_files(part_name, &dep_count, &names);// 获取关联文件
105             for (k = 0; k < dep_count; k++)
106                 PRINT(("Dependent files: %s", names[k]));
107 
108             indent_level--;
109             if (dep_count > 0)
110                 UF_free_string_array(dep_count, names);
111         }
112         if (count > 0){
113             UF_free_string_array(count, file_types);
114             UF_free_string_array(count, file_names);
115         }
116     }
117     indent_level--;
118     UF_free(revisions);
119     revisions = NULL;
120     return _errCode;
121 }
122 
123 static int list_in_folder(UF_UGMGR_tag_t folder)
124 {    
125     int _errCode = 0;
126     char folder_name[UF_UGMGR_NAME_SIZE + 1];
127     if (folder == UF_UGMGR_null_tag) return -1;
128 
129     _errCode = UF_UGMGR_ask_folder_name(folder, folder_name);// 获取文件夹名称
130     PRINT(("Folder: %s", folder_name));
131     indent_level++;
132 
133     UF_UGMGR_object_type_t object_type;
134     int root_folder_contents_count = 0;
135     UF_UGMGR_tag_t * folder_contents = NULL;
136     _errCode = UF_UGMGR_list_folder_contents(folder, &root_folder_contents_count, &folder_contents);// 列出文件夹下的所有文件
137     for (int idx = 0; idx < root_folder_contents_count; idx++)
138     {
139         _errCode = UF_UGMGR_ask_object_type(folder_contents[idx], &object_type);// 获取文件类型
140         switch (object_type)
141         {
142         case UF_UGMGR_type_folder:
143             list_in_folder(folder_contents[idx]);// 是文件夹
144             break;
145         case UF_UGMGR_type_part:
146             list_in_part(folder_contents[idx]);// 是零组件
147             break;
148         default:
149             printf("Invalid object type found");
150             break;
151         }
152     }
153     UF_free(folder_contents);
154     folder_contents = NULL;
155     indent_level--;
156     return _errCode;
157 }
158 
159 void do_it()
160 {
161     int _errCode = 0;
162 
163     tag_t partTag = NULL_TAG;
164     UF_PART_load_status_t error_status;
165     UF_UGMGR_tag_t database_part_tag = NULL_TAG;
166     UF_UGMGR_tag_t part_revision = NULL_TAG;
167     UF_UGMGR_tag_t root_folder_tag = NULL_TAG;
168     UF_UGMGR_tag_t user_folder_tag = NULL_TAG;
169 
170     char current_rule[UF_UGMGR_NAME_BUFSIZE] = { 0 };
171     char revision_id[UF_UGMGR_NAME_BUFSIZE] = { 0 };
172     char export_dir_name[MAX_FSPEC_BUFSIZE] = { 0 };
173     char encoded_name[MAX_FSPEC_BUFSIZE] = { 0 };
174     char user_role[UF_UGMGR_ROLE_BUFSIZE] = { 0 };
175 
176     _errCode = UF_UGMGR_ask_part_tag("000000000AA000082", &database_part_tag);// 获取编码为000000000AA000082的部件标识
177     _errCode = UF_UGMGR_ask_config_rule(current_rule);// 获取默认配置规则
178     std::cout << "默认配置规则:" << current_rule << std::endl;
179     _errCode = UF_UGMGR_set_config_rule("Latest Working");// 设置配置规则
180     _errCode = UF_UGMGR_ask_configured_rev(database_part_tag, &part_revision);// 获取配置版本
181     _errCode = UF_UGMGR_ask_part_revision_id(part_revision, revision_id);// 获取版本ID
182 
183     _errCode = UF_UGMGR_ask_root_folder(&root_folder_tag);// 获取用户根文件夹,即HOME文件夹标识
184     _errCode = UF_UGMGR_ask_user_folder("infodba", &user_folder_tag);// 获取用户文件夹
185     _errCode = UF_UGMGR_ask_user_role(user_role);// 获取用户角色
186 
187     std::cout << "\n=================用户文件夹下文件=================" << std::endl;
188     _errCode = list_in_folder(root_folder_tag);// 列出该文件夹下地下所有文件夹和零组件
189     std::cout << "=================用户文件夹下文件=================\n" << std::endl;
190 
191     int config_rules_count = 0;
192     char ** config_rules = NULL;
193     _errCode = UF_UGMGR_list_config_rules(&config_rules_count, &config_rules);// 列出所有配置规则,并打印到控制台
194     std::cout << "\n=================所有配置规则=================" << std::endl;
195     for (int idx = 0; idx < config_rules_count; idx++)
196         std::cout << config_rules[idx] << std::endl;
197     UF_free(config_rules);
198     config_rules = NULL;
199     std::cout << "=================所有配置规则=================\n" << std::endl;
200 
201     int file_count = 0;
202     char** file_types = NULL;
203     char** file_names = NULL;
204     _errCode = UF_UGMGR_list_part_rev_files(part_revision, &file_count, &file_types, &file_names);// 列出版本下所有数据集文件
205     if (file_count <= 0) return;
206 
207     for (int idx = 0; idx < file_count; idx++){
208         if (file_names[idx] == NULL) continue;
209 
210         _errCode = UF_UGMGR_encode_part_filename("000000000AA000082", revision_id, file_types[idx], file_names[idx], encoded_name);// encode组成文件名
211         _errCode = UF_PART_open(encoded_name, &partTag, &error_status);// NX后台打开
212         _errCode = UF_UGMGR_ask_export_directory(partTag, export_dir_name);// 获取export文件夹目录
213         std::cout << "临时export文件夹目录:" << export_dir_name << std::endl;
214         _errCode = UF_PART_free_load_status(&error_status);
215         _errCode = UF_PART_close(partTag, 1, 1);
216     }
217     if (file_count > 0){
218         UF_free_string_array(file_count, file_names);
219         UF_free_string_array(file_count, file_types);
220     }
221     file_types = NULL;
222     file_names = NULL;
223 }
224 
225 //===================
226 // Entry Point
227 //===================
228 int main(int argc, char* argv[])
229 {
230     try{
231         int _errCode = 0;
232         const char** consolePara = (const char**)(argv);
233         logical is_active;
234         _errCode = UF_is_ugmanager_active(&is_active);// 判断ugmanager环境是否已经初始化
235         if (!is_active)
236             _errCode = UF_UGMGR_initialize(argc, consolePara);// 初始化ugmanager环境
237         do_it();
238         _errCode = UF_UGMGR_terminate();
239         return _errCode;
240     }
241     catch (const NXException& e1){
242         cerr << "NXException: " << e1.ErrorCode() << endl;
243         cerr << e1.Message() << endl;
244     }
245     catch (const exception& e2){
246         cerr << "Exception: " << e2.what() << endl;
247     }
248     catch (...){
249         cerr << "Unknown Exception: " << endl;
250     }
251 }
View Code

 

调试截图:

 

NX版本配置规则截图:

 

 

版本规则解释:

 

Teamcenter对象介绍:中文是自动翻译的,不准确。详细请看帮助文档:Siemens 文档: Teamcenter Integration for NX

 

集成开发Teamcenter_NXspanstylecolorC++

有关Teamcenter_NX集成开发:UF_UGMGR函数的使用的更多相关文章

  1. ruby - 使用 C 扩展开发 ruby​​gem 时,如何使用 Rspec 在本地进行测试? - 2

    我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当

  2. ruby - 在没有 sass 引擎的情况下使用 sass 颜色函数 - 2

    我想在一个没有Sass引擎的类中使用Sass颜色函数。我已经在项目中使用了sassgem,所以我认为搭载会像以下一样简单:classRectangleincludeSass::Script::FunctionsdefcolorSass::Script::Color.new([0x82,0x39,0x06])enddefrender#hamlengineexecutedwithcontextofself#sothatwithintemlateicouldcall#%stop{offset:'0%',stop:{color:lighten(color)}}endend更新:参见上面的#re

  3. ruby-on-rails - 在 ruby​​ 中使用 gsub 函数替换单词 - 2

    我正在尝试用ruby​​中的gsub函数替换字符串中的某些单词,但有时效果很好,在某些情况下会出现此错误?这种格式有什么问题吗NoMethodError(undefinedmethod`gsub!'fornil:NilClass):模型.rbclassTest"replacethisID1",WAY=>"replacethisID2andID3",DELTA=>"replacethisID4"}end另一个模型.rbclassCheck 最佳答案 啊,我找到了!gsub!是一个非常奇怪的方法。首先,它替换了字符串,所以它实际上修改了

  4. Ruby Sinatra 配置用于生产和开发 - 2

    我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm

  5. ruby-on-rails - 如何使辅助方法在 Rails 集成测试中可用? - 2

    我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel

  6. ruby - 在 Ruby 中有条件地定义函数 - 2

    我有一些代码在几个不同的位置之一运行:作为具有调试输出的命令行工具,作为不接受任何输出的更大程序的一部分,以及在Rails环境中。有时我需要根据代码的位置对代码进行细微的更改,我意识到以下样式似乎可行:print"Testingnestedfunctionsdefined\n"CLI=trueifCLIdeftest_printprint"CommandLineVersion\n"endelsedeftest_printprint"ReleaseVersion\n"endendtest_print()这导致:TestingnestedfunctionsdefinedCommandLin

  7. ruby - 是否可以覆盖 gemfile 进行本地开发? - 2

    我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI

  8. ruby-on-rails - 我如何将 Hoptoad 与 DelayedJob 和 DaemonSpawn 集成? - 2

    我一直很高兴地使用DelayedJob习惯用法:foo.send_later(:bar)这会调用DelayedJob进程中对象foo的方法bar。我一直在使用DaemonSpawn在我的服务器上启动DelayedJob进程。但是...如果foo抛出异常,Hoptoad不会捕获它。这是任何这些包中的错误...还是我需要更改某些配置...或者我是否需要在DS或DJ中插入一些异常处理来调用Hoptoad通知程序?回应下面的第一条评论。classDelayedJobWorker 最佳答案 尝试monkeypatchingDelayed::W

  9. ruby - 在 Windows 机器上使用 Ruby 进行开发是否会适得其反? - 2

    这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby​​-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub

  10. ruby-on-rails - 在 Rails 开发环境中为 .ogv 文件设置 Mime 类型 - 2

    我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain

随机推荐