Перейти к публикации

Рекомендованные сообщения

6 минут назад, Sla_68 сказал:

с разными суммами

:biggrin: дык в поле "Сколько" можно вбить сколько не жалко. А по-умолчанию там стоит просто самое малое.

Ссылка на сообщение
Поделиться на других сайтах


12 минуты назад, streamdown сказал:

:biggrin: дык в поле "Сколько" можно вбить сколько не жалко. А по-умолчанию там стоит просто самое малое.

Вот я опять опростоволосился.:wallbash:

Ссылка на сообщение
Поделиться на других сайтах

Табличку вставляю макросом , а она чет не хочет отверстия вытягивать. Может есть какие либо догадки? Дело вот в чем, плоскость выделяется ровно как и вершина там где они должны быть, т.е правильно. Я в начале грешил на то что не та плоскость и не та вершина. Но потом повернул вид инструментом 3й вид и заново прогнал строки кода отвечающие за выделение. Все там где надо выделено.

Sub вставка_таблицы_отверстий() 
Dim swView As SldWorks.View
Dim vScaleRatio As Variant
Dim swDrawing  As SldWorks.drawingDoc
Dim swSelData As SldWorks.SelectData
Dim swModel As SldWorks.ModelDoc2
Set swApp = Application.SldWorks
 Set swModel = swApp.ActiveDoc
Set swSelMgr = swModel.SelectionManager
Set swSelData = swSelMgr.CreateSelectData
Set Part = swApp.ActiveDoc
Set swDrawing = swApp.ActiveDoc

f = BrowseForFileOpen("открыть", "*", "")
Set myView = swDrawing.CreateDrawViewFromModelView3(f, "*Спереди", 0.105, 0.1485, 0)
vComps = myView.GetVisibleComponents
Set Comp = vComps(0)

vfaces = myView.GetVisibleEntities2(Comp, swViewEntityType_Face)
vvertex = myView.GetVisibleEntities2(Comp, swViewEntityType_Vertex)

For i = LBound(vfaces) To UBound(vfaces)
        xName = swDrawing.GetEntityName(vfaces(i))
    If xName = "speredy" Then
        vfaces(i).Select4 False, swSelData
        Exit For
    End If
Next
For i = LBound(vvertex) To UBound(vvertex)
        xName = swDrawing.GetEntityName(vvertex(i))
    If xName = "vertex" Then
        vvertex(i).Select4 True, swSelData
        Exit For
    End If
Next

shahole = "C:\Program Files\SOLIDWORKS Corp\SOLIDWORKS\lang\russian\standard hole table--letters.sldholtbt"

Set myHoleTable = myView.InsertHoleTable2(False, -0.15, 0.2, swBOMConfigurationAnchor_TopLeft, "F", shahole)
 
 ' авторазмеры_чертежа

End Sub

 

hole.jpg

Ссылка на сообщение
Поделиться на других сайтах

@Sla_68 Ещё раз: для вставки таблицы у вас должно быть выделено Vertex и Face. Проверьте перед вставкой что они выделены. (GetSelectedObjectCount) Так же, 

shahole ??? это путь в шаблону? В этом параметре либо пустота, либо полный путь к шаблону таблицы.
Ссылка на сообщение
Поделиться на других сайтах

Все верно . Выделяется и вершина, и плоскость. Это и видно,и много раз я перепроверил. 

shahole -переменная string - полный путь к шаблону таблицы отверстий. (А на скринне результат работы макроса.) BrowseForFileOpen-ваш код для открытия файла. Сам файл я предварительно  укомплетовал наименованиями вершины и плоскости.


 
Ссылка на сообщение
Поделиться на других сайтах

@Sla_68 ладушки. Тогда магия)))

Dim swApp As SldWorks.SldWorks
Dim swModel As SldWorks.ModelDoc2
Dim swSelMgr As SldWorks.SelectionMgr
Dim swVertex As SldWorks.Entity
Dim swView As SldWorks.View
Dim swSelData As SldWorks.SelectData
Sub main()
    Set swApp = Application.SldWorks
    
    Set swModel = swApp.ActiveDoc
    
    Set swSelMgr = swModel.SelectionManager
    Set swSelData = swSelMgr.CreateSelectData
    Set myView = swSelMgr.GetSelectedObjectsDrawingView2(1, -1)
    
    vComps = myView.GetVisibleComponents
Set Comp = vComps(0)
'vfaces = myView.GetVisibleEntities2(Comp, swViewEntityType_Face)
vvertex = myView.GetVisibleEntities2(Comp, swViewEntityType_Edge)
Dim vVisComps As Variant
    vVisComps = myView.GetVisibleComponents
    Dim i As Integer
    
    
For i = 0 To UBound(vVisComps)
        Dim vVisFaces As Variant
        vVisFaces = myView.GetVisibleEntities(vVisComps(i), swViewEntityType_e.swViewEntityType_Face)
        Dim j As Integer
        For j = 0 To UBound(vVisFaces)
            Dim swEnt As SldWorks.Entity
            Set swEnt = vVisFaces(j)
            swEnt.SelectByMark True, 2
        Next
    Next
    
For i = LBound(vvertex) To UBound(vvertex)
        xName = swModel.GetEntityName(vvertex(i))
    If xName = "vertex" Then
        vvertex(i).SelectByMark True, 1
        Exit For
    End If
Next
shahole = "C:\Program Files\SOLIDWORKS Corp\SOLIDWORKS\lang\russian\standard hole table--letters.sldholtbt"
Set myHoleTable = myView.InsertHoleTable2(False, -0.15, 0.2, swBOMConfigurationAnchor_TopLeft, "F", shahole)

End Sub

 

Ссылка на сообщение
Поделиться на других сайтах

Я всегда верю в то что я сам виноват. Просто, что то зевнул. Проверю сегодня завтра свежим взглядом, глядишь и найдется решение. А еще верю в то, что безвыходных ситуаций не бывает.

Ссылка на сообщение
Поделиться на других сайтах
В 20.12.2017 в 08:43, streamdown сказал:

@Sla_68 ладушки. Тогда магия)))

Это ведь готовое решение. А я вчера уходя на работу даже и не понял. А ведь оно еще и отлично работает.

Получается что нужно еще добраться  "видимого компонента" в первом цикле. Поскольку могут быть другие детали или сборки.  Это понятно. А вот метод выделения плоскости  я до конца не понял.

myView.GetVisibleEntities

вы берете плоскости вот этим методом. Но я не понимаю почему  в цикл J вытаскивает плоскости под наклоном (фаски )и но не вытаскивает  такое как дно несквозного отверстия на основной видимой плоскости? Пока что действительно магия.

 

Ссылка на сообщение
Поделиться на других сайтах
30 минут назад, Sla_68 сказал:

дно несквозного отверстия

Хмм..попробуйте у компонента высветить скрытые кромки, может и найдёт "дно". Не знаю)))

Магия то она магия, но вот глюков в API оооочень мало. А значит для чего-то это было сделано (подсветка плоскости под наклоном)

Ссылка на сообщение
Поделиться на других сайтах
27 минут назад, streamdown сказал:

Хмм..попробуйте у компонента высветить скрытые кромки, может и найдёт "дно". Не знаю)))

Магия то она магия, но вот глюков в API оооочень мало. А значит для чего-то это было сделано (подсветка плоскости под наклоном)

Все работает. А вот на счет глюков API скажу свое небольшое наблюдение. Если работать в VBA Excel, то вы после того как отработает ваш макрос не можете вернуть действия макроса кнопкой назад. А в sw -это возможно. Поэтому я сделал вывод что API SW -это  управление кнопками пользователя в какой то степени. А это значит что глюков не может быть больше чем при обычном использовании программы.

Принципы работы API архитектурно различны.

 

Кстати мой макрос тоже работает, как выяснилось виновата seldata. Если у меня заменить "vfaces(i).Select4 False, swSelData "  на "vfaces(i).SelectByMark True, 2" то все тоже работает. SelectByMark  раньше не использовал.
       

Ссылка на сообщение
Поделиться на других сайтах

Я вообще нигде и никогда не использовал SelData. Оно вроде как для последующего восстановления выделения. Мне такое нигде не надо было. Поэтому код обычно с SelData=null

Ссылка на сообщение
Поделиться на других сайтах

Доброго вечера. С табличкой разобрался.  Сейчас кружусь пока с местоположением на чертеже аннотаций. Задача стоить вокруг контура плоскости, состоящего из линий и дуг выносить за предел этого контура аннотации.  Я думал что это не составит труда сделать а получилось "как всегда"  . Для расчета центра текстового поля беру точки вершин. Пытаюсь центр каждого ребра детали высчитать по формуле xc=(x1+x2)/2 yc=(y1+y2)/2. Но такой расчет подходит для трехмерного пространства , а не для листа.  Т.е. получается нужно с учетом масштаба листа, масштаба вида вставки, точки вставки вида  вычислить нужные мне координаты. Чет уже голова кругом от этих геморов. Может есть более простой способ трансформации? А так вообще свихнуться можно. Вообщем нужен совет. Я прям растерян. На скрин выложил примерно то что хотелось бы сделать.

выноски.jpg

Ссылка на сообщение
Поделиться на других сайтах

@Sla_68  с аннотациями на картинке чуток сложнее. Максимум что делал - так это вставлял заметку по центру грани компонента в сборочном. Вечерком посмотрю остался ли тот старый код.

Ссылка на сообщение
Поделиться на других сайтах

Есть ли возможность увидеть объекты&свойства VBA SW в  виде "дерева"?

Ссылка на сообщение
Поделиться на других сайтах
  • 2 недели спустя...

Приветствую , интересует написание очень простого макроса на !!!VBA!!!, связанного с таблицами в SW.

по выделенному чертежу виду макрос

1. создаёт спецификацию (!!!плоскую!!!)

2. скрывает строки  Деталей  

3. копирует все данные в массив.

Как создать плоскую спецификацию я разобрался,как скрыть нужные строки и как всё закинуть в массив - не понятно

 

Dim swApp As Object

Dim Part As Object
Dim boolstatus As Boolean
Dim longstatus As Long, longwarnings As Long

 

Sub main()

Set swApp = Application.SldWorks

Set Part = swApp.ActiveDoc
Part.ClearSelection2 True
Dim swActiveView As Object
Set swActiveView = Part.ActiveDrawingView
Dim swBOMTable As Object
Set swBOMTable = swActiveView.InsertBomTable4(False, 0.43, 0.29, swBOMConfigurationAnchorType_e.swBOMConfigurationAnchor_TopLeft, swBomType_e.swBomType_Indented, "По умолчанию<Как сварной>", "", False, swNumberingType_e.swNumberingType_Flat, True)
boolstatus = Part.EditRebuild3()
End Sub

Снимок.PNG

Ссылка на сообщение
Поделиться на других сайтах
19 минут назад, Riful сказал:

Приветствую , интересует написание очень простого макроса на !!!VBA!!!, связанного с таблицами в SW.

по выделенному чертежу виду макрос

1. создаёт спецификацию (!!!плоскую!!!)

2. скрывает строки  Деталей  

3. копирует все данные в массив.

Как создать плоскую спецификацию я разобрался,как скрыть нужные строки и как всё закинуть в массив - не понятно

Добрый вечер. У вас очень непонятное тз.  кроме п 1 . В п. 2 я не уверен что можно скрыть строки. А вот столбцы скорее всего можно. В п. 3 не понятно зачем вам массив. Обычно массив это переменная в коде для хранения каких либо данных. И эти данные в последствии как либо используются.

Ссылка на сообщение
Поделиться на других сайтах
41 минуту назад, Sla_68 сказал:

Добрый вечер. У вас очень непонятное тз.  кроме п 1 . В п. 2 я не уверен что можно скрыть строки. А вот столбцы скорее всего можно. В п. 3 не понятно зачем вам массив. Обычно массив это переменная в коде для хранения каких либо данных. И эти данные в последствии как либо используются.

Приветствую! Скрыть Деталь1 и похожие нужно потому, что это ненужная информация в моём случае, в принципе, если это невозможно или сложно, это можно сделать и вручную. А массив нужен для обработки данных полученных из спецификации и составления еще 2 таблиц на основе результатов обработки массива. Поэтому желательно закинуть данные с таблицы в двумерный массив, только я не могу понять как это сделать.

Изменено пользователем Riful
Ссылка на сообщение
Поделиться на других сайтах

Всем спасибо , разобрался. Приравниваем  swBOMTable2 As SldWorks.TableAnnotation к той таблице и гоняем данные и скрываем всё что угодно как хотим.

 

Dim swBOMTable2 As SldWorks.TableAnnotation
Set swBOMTable2 = swBOMTable

MsgBox swBOMTable2.Text(4, 4)
swBOMTable2.Text(4, 4) = "lol change"
swBOMTable2.ColumnHidden(3) = True
 

Ссылка на сообщение
Поделиться на других сайтах
  • 2 недели спустя...

Это все надо допиливать под себя, но принцип поймете, комменты все есть, коды открыты. 

BOM to EXCEL.swp

Ну а как автоматически вставить спецификацию - это отдельная тема. Там придется определять тип детали, твердотелка, листовой, сварной и т.д. и по ним выбирать шаблон. Обновить список вырезов для листа и сварного... в общем интересно.

Изменено пользователем v-david
Ссылка на сообщение
Поделиться на других сайтах

Присоединяйтесь к обсуждению

Вы можете опубликовать сообщение сейчас, а зарегистрироваться позже. Если у вас есть аккаунт, войдите в него для написания от своего имени.
Примечание: вашему сообщению потребуется утверждение модератора, прежде чем оно станет доступным.

Гость
Ответить в тему...

×   Вставлено в виде отформатированного текста.   Вставить в виде обычного текста

  Разрешено не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отобразить как ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставить изображения напрямую. Загрузите или вставьте изображения по ссылке.

  • Сейчас на странице   1 пользователь

    • Sla_68


  • Сообщения

    • Snake 60
      Скорее всего исправляли в конкретной сборке, для конкретных тел. Насколько я помню, надо в самом эскизе профиля заполнить свойство Description
    • Snake 60
      Делаете дырку в свае - вставляете в нее трубу и 2 человеко-силы крутят сваю ) Дёшево и сердито и не нужен никакой планетарный редуктор ))
    • gudstartup
      вы всегда ищите свой путь или будете делать то что вам советуют? с самого начала прежде чем приступать к экспериментам вам нужно было вынуть носитель и сделать образ. diskcopy делает копию гибкого диска на другой а вам надо сделать образ жесткого диска или карты памяти. делайте как советует @Viktor2004 иначе еще чего нибудь сломаете или вам станок не нужен и вы его приобрели для экспериментов ? вот а печатной машинке из прошлого нельзя а вот на синумерике можно - удивительные вещи в настоящем происходят!! на 100 % уверен что там не модуль а либо писимиси ай либо жд @mircomax81 хотите работать в дос почитайте помощь по командам 
    • PuKoLLleT
      Доброго дня всем. Поделитесь опытом,раньше такое не доводилось делать. На торце фланца нужно сделать  восемь отверстий ф17H7 на токарно-фрезерном станке с осью Y ,имеется ManualGuide.В моем понимании нужно просверлить,а затем торцевой фрезой расточить нужный диаметр.Получится такой фокус,или надо разверткой доводить нужный размер?  Стойка Fanuc 0i-Tf.
    • Snake 60
      Всё верно, я даже русификатор делал для него (ушло на это где-то около года). Хороший софт был, я всех знакомых на него подсадил в свое время :) У меня даже где-то образ на виртуалке лежит с SW2014+MechSoft, Жаль, что автодеск его поглотил, а не DS :( А по сути вопроса, проектировал двухступенчатый планетарный редуктор в свое время. Что было нужно: Справочник по планетаркам (автора не помню, если надо поищу), из софта MathCAD + GearTeq (софтина идет вместе с GearTrax, только рассчитывает и моделирует несколько зацеплений согласно выбранной схеме, в том числе планетарки) Ой и ошибаетесь. Звездочки - не равно зубчатые колеса в планетарке) Мы намучились с малой точностью изготовления на эл.эрозии, а Вы лазером ))) Был собран опытный образец редуктора с незакаленными деталями, чисто проверить геометрию, отладить сборку. Так потом начальство этот редуктор сказало испытать в бою, как я не противился)) Помер за пару дней интенсивных нагрузок ))) Материал, термообработка и точности изготовления решают )
    • Snake 60
      @Тихоход  Ещё один вариант - изучать программирование и писать свою программу/макрос. Вот пример конфигуратора двери: https://www.youtube.com/watch?v=wv4HryWQBSk
    • mircomax81
      Посредством Diskcopy можно сделать адекватную копию на флоппи диск?
    • Andrey_kzn
      Да, ведь советовали автору вытащить жёсткий диск и сделать образ. Неужели самому не интересно, как устроен этот старый промкомпьютер? Там может стоять как жёсткий диск, так и CF-карта, или же Disc-on-chip или Disc-on-module.  Как-то очень давно, на подобном промышленном оборудовании (большая печатная машина) я не смог перенести  ПО с родной CF - карты на другую, такого же размера но другой фирмы. Была также станочная оболочка под досом.  Образ я делал Нортон гостом, развернул его на другую CF-карту без проблем. Машина загрузилась нормально и работала ровно 2 дня, на неродной CF-карте,  потом зависла, и отказалась загружаться. Пришлось вызывать сервисника. От него мы узнали, что нельзя просто так взять и заменить карту  - носитель системного ПО, на другую. А полезли мы туда, так как руководство захотело печатать отчёты по работе машины. В станочном ПО такая функция была. Вот только принтер надо было купить у фирмы - производителя этой самой машины. В попытках заставить работать другой принтер мы редактировали файл  AUTOEXEС.BAT, на предмет загрузки драйвера принтера, ничего не получилось, зато перестали открываться некоторые страницы станочного ПО.  Образ у нас был давно снят, и мы развернули его на другую карту памяти. Родную карту я трогать не стал (как чувствовал, что нельзя ). Сервисник восстановил ПО с архивной дискеты на родную карту памяти, и всё заработало. Дискеты с архивами ПО шли вместе с документацией к машине.  Там были дискеты с Досом, станочной оболочкой, параметрами приводов, программой ПЛК. Он же и предупредил нас о предельно аккуратном обращении с родной картой памяти, и посоветовал немедленно сделать образы с архивных дискет, что мы сразу и проделали.. Вот такой сюрприз от машины эпохи Дос.
    • Борман
    • gudstartup
      а ведь все работало...
×
×
  • Создать...