Официальный форум российского программного комплекса T-FLEX PLM


Поиск  Правила 
Закрыть
Логин:
Пароль:
Забыли свой пароль?
Регистрация
Войти
 
Выбрать дату в календареВыбрать дату в календаре

Страницы: 1
Получить путь связанного объекта(файла) из Структуры изделия
 
vite, спасибо Вам большое, как всегда выручили!!!
Получить путь связанного объекта(файла) из Структуры изделия
 
vite, подскажите пожалуйста какую ссылку вы используете для определения "SchemeId"?
Ошибка такая: " 'TFlex.Model.ProductStructure' does not contain a definition for 'SchemeId' and no extension method 'SchemeId' accepting a first argument of type 'TFlex.Model.ProductStructure' could be found (are you missing a using directive or an assembly reference?) "
Получить путь связанного объекта(файла) из Структуры изделия
 

Добрый день!

Я работаю с режимом "Структура изделия", все позиции которые есть в структуре изделия выгружаю в pdm систему, но чтобы это сделать нужно открыть каждую деталь и сохранить ее, для этого нужен путь файла. Путь файла искала в режиме 3D модель, обозначение файла брала из структуры изделия и искала соответствие в дереве построения. Но столкнулась с вариантом когда, в дереве построения и в структуре изделия обозначения отличаются, но при этом если в структуре становлюсь на какую-то позицию, то в дереве она подсвечивается. Столкнулась с тем, что могу вытащить путь связанного объекта и отдельно Обозначение и Наименование, но связать их между собой не получается.

На входе имею см. рисунок1.

Далее использую код, который бегает по структуре изделия и считывает Обозначение, Наименование, Путь(расположение связанных объектов) и записывает в таблицу.

Если я использую код:

[CODE] //создаем столбцы в Data Table
          System.Data.DataTable dt = new System.Data.DataTable();
          dt.Columns.Add("NOTE_SPEC", typeof(string));
          dt.Columns.Add("NAME_SPEC", typeof(string));
          dt.Columns.Add("CHECK_POS", typeof(Boolean));
          dt.Columns.Add("Path", typeof(string));
          document = TFlex.Application.ActiveDocument;
          //получаем объекты дерева построения            
          //1-параметр - ссылка на текущую сборку
          //2-параметр - указывает нужно ли, кроме ссылок на grb, возвращать ссылки на картинки, БД.
          //3-параметр - указывает нужно ли возвращать ссылки на библиотечные фрагменты
          //последний параметр - позволяет задать уровень вложенности,
          //для которого нужно получить ссылки(false - 1 уровень вложенности, true - поиск на всю глубину сборки)
          string[] filePaths = TFlex.Application.GetDocumentExternalFileLinks(document.FileName, false, false, false);

          //бегаем по спецификации T-flex
          foreach (var ps in document.GetProductStructures())
          {
              //перебор всех элементов/записей
              foreach (var elem in ps.GetAllRowElements())
              {
                  var includeInReport = (bool)elem.IncludeInDoc.Value; //true/false если стоит галочка включать в спецификацию
                  d = elem.SourceFragmentPath; //расположение (путь) связанного объекта

                  if (d != null)
                  {
                      //перебор групп(разделов) "главного" представления:
                      foreach (var group in ps.GetRowElementGroups())
                      {
                          string groupName = group.Name;

                          if ((groupName == "Документация") || (groupName == "Сборочные единицы") || (groupName == "Детали") || (groupName == "Прочие изделия"))
                          {
                              foreach (var item in group.Items)
                              {
                                  //Значения элемента
                                  dynamic mainElem = item.MergedElements.First();
                                  string paramValue = mainElem[new Guid("ee9a8bc0-c016-4915-9baa-69b2d8c28786")].ValueAsString; //обозначение
                                  string paramValue1 = mainElem[new Guid("44bb724a-de07-4fd3-9882-ced1c8425057")].ValueAsString; //наименование

                                  if ((groupName == "Документация") || (groupName == "Детали") || (groupName == "Сборочные единицы") || (groupName == "Прочие изделия"))
                                  {
                                      //добавляем строку в Data Table и запоняем ее
                                      DataRow newRow = dt.Rows.Add();
                                      newRow.SetField("NOTE_SPEC", paramValue);
                                      newRow.SetField("NAME_SPEC", paramValue1);
                                      newRow.SetField("CHECK_POS", true);
                                      count_row = Convert.ToInt16(dt.Rows.Count.ToString());

                                      if (paramValue.Contains(" СБ") == true)
                                      {
                                          string paths = document.FileName.ToString();
                                          newRow.SetField("path", paths); //заполняем строку
                                      }
                                      else
                                      {
                                          newRow.SetField("path", d); //заполняем строку
                                      }
                                  }
                              }
                          }
                      }
                  }
              }  
          }
          gridContrl.DataSource = null;
          gridContrl.DataSource = dt;

[/CODE]
то на выходе получаю (см.рисунок2). Обратите внимание, что колонки Обозначение и Расположение файла не соответствуют.

Если использую код, который вытаскивает правильно Обозначение, то не могу получить Расположение файла, так как SourceFragmentPath есть только в GetAllRowElements. (см. рисунок3)[CODE]//создаем столбцы в Data Table
           System.Data.DataTable dt = new System.Data.DataTable();
           dt.Columns.Add("NOTE_SPEC", typeof(string));
           dt.Columns.Add("NAME_SPEC", typeof(string));
           dt.Columns.Add("CHECK_POS", typeof(Boolean));
           dt.Columns.Add("Path", typeof(string));
           document = TFlex.Application.ActiveDocument;
           //получаем объекты дерева построения            
           //1-параметр - ссылка на текущую сборку
           //2-параметр - указывает нужно ли, кроме ссылок на grb, возвращать ссылки на картинки, БД.
           //3-параметр - указывает нужно ли возвращать ссылки на библиотечные фрагменты
           //последний параметр - позволяет задать уровень вложенности,
           //для которого нужно получить ссылки(false - 1 уровень вложенности, true - поиск на всю глубину сборки)
           string[] filePaths = TFlex.Application.GetDocumentExternalFileLinks(document.FileName, false, false, false);

           //бегаем по спецификации T-flex
           foreach (var ps in document.GetProductStructures())
           {
               //перебор всех элементов/записей
               foreach (var elem in ps.GetAllRowElements())
               {
                   var includeInReport = (bool)elem.IncludeInDoc.Value; //true/false если стоит галочка включать в спецификацию
                   d = elem.SourceFragmentPath; //расположение (путь) связанного объекта
               }
                   if (d != null)
                   {
                       //перебор групп(разделов) "главного" представления:
                       foreach (var group in ps.GetRowElementGroups())
                       {
                           string groupName = group.Name;

                           if ((groupName == "Документация") || (groupName == "Сборочные единицы") || (groupName == "Детали") || (groupName == "Прочие изделия"))
                           {
                               foreach (var item in group.Items)
                               {
                                   //Значения элемента
                                   dynamic mainElem = item.MergedElements.First();
                                   string paramValue = mainElem[new Guid("ee9a8bc0-c016-4915-9baa-69b2d8c28786")].ValueAsString; //обозначение
                                   string paramValue1 = mainElem[new Guid("44bb724a-de07-4fd3-9882-ced1c8425057")].ValueAsString; //наименование

                                   if ((groupName == "Документация") || (groupName == "Детали") || (groupName == "Сборочные единицы") || (groupName == "Прочие изделия"))
                                   {
                                       //добавляем строку в Data Table и запоняем ее
                                       DataRow newRow = dt.Rows.Add();
                                       newRow.SetField("NOTE_SPEC", paramValue);
                                       newRow.SetField("NAME_SPEC", paramValue1);
                                       newRow.SetField("CHECK_POS", true);
                                       count_row = Convert.ToInt16(dt.Rows.Count.ToString());

                                       if (paramValue.Contains(" СБ") == true)
                                       {
                                           string paths = document.FileName.ToString();
                                           newRow.SetField("path", paths); //заполняем строку
                                       }
                                       else
                                       {
                                           newRow.SetField("path", d); //заполняем строку
                                       }
                                   }
                               }
                           }
                       }
                   }
               //}  
           }
           gridContrl.DataSource = null;
           gridContrl.DataSource = dt;[/CODE]

Получается я могу получить либо только расположение файлов, либо реальные обозначение и наименование деталей.

Подскажите пожалуйста, как получить и Расположение связанных объектов, и Обозначение, и Наименование, при этом сохранив все условия из кода?

Сайт и Форум, Замечания и предложения по сайту и форуму
 
Здравствуйте! Больше месяца на форуме не работает Поиск. Если в поисковой строке написать "document" и выбрать раздел поиска "[URL=http://www.tflex.ru/forum/index.php?PAGE_NAME=list&FID=14]Программирование приложений, T-FLEX OPEN API[/URL]", то поиск осуществляется только с 23.02.2019 года.
Для примера тема "Получить все сборки, детали, стандартные изделия входящие в 3D модель", которая не попала в результат поиска, на самом деле таких тем очень много.
20.02.2019 в техподдержку отправила письмо с этой проблемой , но они молчат.
Создание меню после открытия документа
 
Ответили из техподдержки:

"В настоящий момент создание меню для плагинов вне метода OnCreateTools() не предусмотрено.
Все действия по созданию меню и подменю выполняются внутри тела метода OnCreateTools()."
Создание меню после открытия документа
 
vite, спасибо, так и сделаю.
Создание меню после открытия документа
 
vite, переменную submenu делала глобальной, но результат тот же. Я правильно поняла, что нельзя создать меню и подменю после открытия документа?
Создание меню после открытия документа
 
vite, переменную submenu я делала глобальной, но ошибка таже.
Я правильно понимаю что после открытия документа не получится создать подменю?
Создание меню после открытия документа
 
Добрый день!

На основе примера StarPlagin в разделе Сервис создала меню, оно появляется при запуске программы и все прекрасно работает.[CODE]protected override void OnCreateTools()
       {

           RegisterCommand((int)Commands.Create, "Создание документа в TechnologiCS", LoadIconResource("testObjectIcon"), LoadIconResource("testObjectIcon")); // Регистрируем команду создания
           //-----------------------------------------------------------------------------------

           TFlex.Menu submenu = new TFlex.Menu();

           submenu.CreatePopup();

           submenu.Append((int)Commands.Create, "&Создание документа в TechnologiCS", this);

           TFlex.Application.ActiveMainWindow.InsertPluginSubMenu("Technologics", submenu, MainWindow.InsertMenuPosition.BeginOfTools, this);
       }
[/CODE]
Теперь необходимо, чтобы после открытия документа появлялось подменю в созданном меню.
[CODE]protected override void DocumentOpenEventHandler(DocumentEventArgs args)
       {
           //Событие приходит после открытия документа

           MessageBox.Show("Документ открыт");

           TFlex.Menu submenu2 = null;

           RegisterCommand(4, "Привет", null, null);

           submenu2 = submenu.AppendSubMenu("&Привет");
       }
[/CODE]
Но вместо этого появляется ошибка. см вложение

[IMG WIDTH=336 HEIGHT=156][/IMG]

Может быть кто-то сталкивался с подобной задачей и знает решение, ну или мысли какие-то есть?
Изменено: Анна - 25.03.2019 08:42:47
Обработка меню и подменю созданные в разделе Сервис
 
[QUOTE]Sila Musli написал:
[QUOTE][URL=/forum/index.php?PAGE_NAME=profile_view&UID=76194&dispatch=categories.view&category_id=1646]Анна[/URL] написал:
интеграцию T-flex CAD с нашей программой[/QUOTE]
Так у них интеграции с Флексом нет. Будете сами писать этот модуль? Не проще ли у них заказать? Или не городить огород и перейти на Докс?)) Родная интеграция не тоже самое, что через атрибуты, Докс с кадом дружит через переменные. И не понятно, почему подписание должно быть в каде, этож чистый пдм?[/QUOTE]
Sila Musli, да, мы сами пишем свое приложение. Переходить на докс нет смысла и платить за написание приложения тоже, так как все меняется на ходу.
Обработка меню и подменю созданные в разделе Сервис
 
vite, спасибо большое!
Обработка меню и подменю созданные в разделе Сервис
 
[QUOTE]Sila Musli написал:
Хотите написать свой DOCs???[/QUOTE]
На предприятии давно установлена система PLM (TechnologiCS), поэтому нужно осуществить интеграцию T-flex CAD с нашей программой.
Обработка меню и подменю созданные в разделе Сервис
 
Добрый день!

На основе примера StarsPlugin, создала меню с выпадающим списком (см.вложение), который строится динамически на основе sql запроса. Человек который будет пользоваться этим меню, может выбрать любой пункт подменю.
Как определить какой пункт подменю выбрал пользователь, т.е. нажал левой клавишей мышки по одной из строк сформированных динамически?
Перебор страниц в документе
 
Ответили с техподдержки:
[CODE]using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows.Forms;
using TFlex.Model;
using TFlex.Model.Model2D;
using TFlex.Model.Model3D;

namespace NewMacroNamespace
{
public class NewMacroClass
{
private static readonly string changeName = "Активировать 2D вид";

public static void Run()
       {
           Document document = TFlex.Application.ActiveDocument;
           if (document == null)
               return;
           try
           {
               document.BeginChanges(changeName);
               Activate2DView(document);
               document.EndChanges();
           }
           catch (Exception msg)
           {
               MessageBox.Show(msg.ToString());
           }
       }

       public static void Activate2DView(Document document)
       {
           View2D view2D = document.ActiveView as View2D;
           if (view2D == null)
               view2D = document.Views.Select(v => v as View2D).Where(v => v != null).FirstOrDefault();
           if (view2D == null)
               view2D = document.Open2DView() as View2D;
           if (view2D == null)
return;
//закрыть 3D вид(отображается только 2D вид)
   Close3DView(document);

           document.Activate();
           view2D.Activate();
           document.Save();
       }

private static void Close3DView(Document document)
       {
           var views3D = document.Views.Select(v => v as View3D).Where(v => v != null);
           if (views3D != null)
           {
               foreach (var view3D in views3D)
               {
                   view3D.Close();
               }
           }
       }
}
}
[/CODE]
Перебор страниц в документе
 
Написали в техподдержке:
[CODE]using System;
using System.Collections.Generic;
using System.Linq;
using System.Windows.Forms;
using TFlex.Model;
using TFlex.Model.Model2D;
using TFlex.Model.Model3D;

namespace NewMacroNamespace
{
public class NewMacroClass
{
private static readonly string changeName = "Работа со страницами документа";
       private static readonly string page1Name = "Страница 1";
       private static readonly string page2Name = "Страница 2";
       private static readonly string specPageName = "Спецификация";
private static readonly string pageNotFoundMsg = "Не найдена страница: ";
       private static readonly string viewNotFoundMsg = "Не найден 2D вид";

       public static void Run()
       {
           Document document = TFlex.Application.ActiveDocument;
           if (document == null)
               return;
           try
           {
               document.BeginChanges(changeName);
               RunPageOperations(document);
               document.EndChanges();
           }
           catch (Exception msg)
           {
               MessageBox.Show(msg.ToString());
           }
       }

       private static void RunPageOperations(Document document)
       {
           View2D view2D = GetView2D(document);
           if (view2D != null)
           {
               //работа со страницей 2
               Page page2 = GetPageByName(document, page2Name);
               if (page2 != null)
               {
                   SetActivePage(document, view2D, page2);

                   //действия со страницей2
                   //...
               }
else
               {
                   MessageBox.Show(string.Format(pageNotFoundMsg + page2Name));
               }

               //работа со страницей спецификация
               Page specificationPage = GetPageByName(document, specPageName);
               if (specificationPage != null)
               {
                   SetActivePage(document, view2D, specificationPage);

                   //действия со страницей2
                   //...
               }
else
               {
                   MessageBox.Show(string.Format(pageNotFoundMsg + specPageName));
               }

               //возврат к исходной странице
               Page page1 = GetPageByName(document, page1Name);
               if (page1 != null)
               {
                   SetActivePage(document, view2D, page1);
               }
else
               {
                   MessageBox.Show(string.Format(pageNotFoundMsg + page1Name));
               }
           }
           else
           {
               MessageBox.Show(viewNotFoundMsg);
           }
       }

private static void SetActivePage(Document document, View2D view2D, Page page2)
       {
           view2D.Page = page2;
           document.Activate();
           view2D.Activate();
           //document.Save();
       }

       private static View2D GetView2D(Document document)
       {
           View2D view2D = document.ActiveView as View2D;
           if (view2D == null)
               view2D = document.Views.Select(v => v as View2D).Where(v => v != null).FirstOrDefault();
           if (view2D == null)
               view2D = document.Open2DView() as View2D;
           if (view2D == null)
               return null;
           return view2D;
       }

       private static Page GetPageByName(Document sourceDocument, string receivePageName)
       {
           return sourceDocument.GetPages().Where(page => page.Name == receivePageName).FirstOrDefault();
       }
}
}
[/CODE]
Получить все сборки, детали, стандартные изделия входящие в 3D модель
 
vite, Благодарю, все работает!
Получить все сборки, детали, стандартные изделия входящие в 3D модель
 
Здравствуйте! Подскажите пожалуйста, как макросом пробежаться по дереву построения 3D модели сборки и получить имена, пути входящих деталей, сборок и т.д.? T-flex 15.1.70.0
Написала в техподдержку, но они молчат  :(
Перебор страниц в документе
 
vite, спасибо большое! Все работает!

Единственно заменила          [CODE]switch (g.PageType) // определение типа страницы
[/CODE]на[CODE]PageType p_type = g.PageType;
switch (p_type) // определение типа страницы
[/CODE]так как C# ругался на тип "g.PageType".
Перебор страниц в документе
 
Здравствуйте! В документе есть несколько  страниц (Страница1, Страница2, Спецификация), Страница1 активная. Подскажите пожалуйста, как макросом можно перебрать все страницы документа и сделать Страницу2 активной, выполнить определенные действия, сделать Срецификацию активной, выполнить определенный действия и вернуться к Странице1?
Страницы: 1