Teamcenter_NX集成開發:UF_UGMGR函數的使用

来源:https://www.cnblogs.com/huangym1/archive/2023/03/23/17246405.html
-Advertisement-
Play Games

最近工作中經常使用Teamcenter、NX集成開發的情況,因此在這裡記錄UF_UGMGR函數的使用。使用UF_UGMGR相關函數需要有Teamcenter使用經驗,理解Teamcenter中文件夾、偽文件夾、零組件、零組件版本、數據集、關係、表單、命名引用等對象。 相關的可以看幫助中 Teamce ...


最近工作中經常使用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

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 每次提交代碼的時候,你是否有為如何寫Commit Message而遲遲按不下提交的時刻呢?然後,死磨硬泡寫了一些並提交後,又被review的小伙伴吐槽了呢?相信很多小伙伴有過這樣的經歷吧? 趁著最近ChatGPT那麼火,就來順手推薦一個可以用於解決這個問題的VS Code插件:vscode-gpto ...
  • C++ STL標準庫中提供了多個用於排序的Sort函數,常用的包括有sort() / stable_sort() / partial_sort(),具體的函數用法如下表所示: | 函數 | 用法 | | | | | std::sort(first,last) | 對容器或數組first~last範圍 ...
  • SpringBoot內置Tomcat的配置和切換 1.基本介紹 SpringBoot支持的webServer:Tomcat,Jetty,Undertow 因為在spring-boot-starter-web中,預設導入的是tomcat,因此啟動時使用的web容器就是tomcat。 同時 Spring ...
  • 最近在看了《微信背後的產品觀 - 張小龍手抄版》,其中有段話如下: 用戶需求是零散的,解決方案是歸納抽象的過程 那如何歸納抽象呢?是否有一定的實踐方法論呢?經過一輪探討和學習,有這些答案: 5 Whys 分析法 U 型思考法 等等 二、5 Whys 分析法 5 Whys 法,最初由豐田佐吉開發,併在 ...
  • 多線程 多線程概述 多線程就是電腦用時運行多個任務 但實質上,同一個時間點,只會運行一個任務,只是電腦在不同任務之間來回切換而已。 併發和並行 並行:在同一時間,多個任務分別在多個CPU上進行。 併發:在同一時間,多個任務在同一個CPU交替進行。 線程和進程 進程 獨立性:進程是一個獨立運行的應 ...
  • SpringBoot中註入Servlet&Filter&Listener 1.基本介紹 文檔:SpringBoot中註入Servlet&Filter&Listener 考慮到實際開發業務非常複雜和相容問題,SpringBoot支持將Servlet、Filter、Listener註入spring容器中 ...
  • Styled Components 備忘清單 IT寶庫整理的Styled Components快速參考備忘單提供了使用 CSS in JS 工具的各種方法入門,為開發人員分享快速參考備忘單。 開發速查表大綱 入門 安裝 快速開始 根據 Props 適配 擴展樣式 擴展樣式改變標簽 (as) 自定義組 ...
  • Stylus 備忘清單 IT寶庫整理的Stylus開發速查備忘單旨在快速理解 stylus 所涉及的主要概念,顯示了它的常用方法使用清單入門,為開發人員分享快速參考備忘單。 開發速查表大綱 入門 介紹 支持 CSS 嵌套語法 支持類 python 縮進語法 混合 Mixins 變數 Variable ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...