ИваСерж

Ответы в темах

Просмотр 15 сообщений - с 1 по 15 (из 98 всего)
  • Автор
    Сообщения
  • #4843 Score: 4
    ИваСерж
    Хранитель
    134 pts

    Вот прямо сегодня столкнулся с такой проблемой. Подробней рассказал Лобанов в своих уроках

    https://youtu.be/XIGpuP23k9k?list=PLVCDzVIlOckHsZcqkq3DmzdGcq2503l1G&t=1175

    Решение: создавать элементы не средствами Динамо, с через питон.
    Я использовал команду doc.Create.NewFamilyinstance. Тогда семейства создаются без привязки к Динамо. Если нужно, могу подсказать как работать с NewFamilyinstance.

    p.s.

    import Revit
    clr.ImportExtensions(Revit.Elements)

    Element.ToDSType(False) – если мы создали элемент в Dynamo (и его не было в Revit) – Dynamo будет отслеживать. Т.е. при очередном запуске старый элемент будет удаляться и создаваться новый!

    Element.ToDSType(True) – Dynamo не будет отслеживать и при каждом запуске будут создаваться новые элементы, старые удаляться не будут.

     

    #8643 Score: 3
    ИваСерж
    Хранитель
    134 pts

    Суть вопроса как понимаю я:
    Для программирования в Ревит мы используем АПИ. Динамо это “обертка” (красивая оболочка) над этим АПИ. Питон, встроенный в Динамо – это очередная “обёртка”, но уже для Динамо. Получаем, как лук, завернутые друг в друга программные элементы. По сути, Ревит это “обертка” надо операционной системой. Операционная система – “обертка” над драйверами, драйверы – “обертка” для железа.

    Работая в Питоне мы можем пользоваться:
    1. Методами Питона 2.7 (причем урезанными), если встречаем элемент из Динамо, то его надо “развернуть” – Unwrap
    2. Методами самого Динамо (т.е. из кода Питона мы можем обращаться к нодам Динамо.

    В Питоне 2.7 нет метода IndexOf, зато есть нод с таким именем в Динамо. Можете вытащить этот нод и посмотреть как он работает. В коде вы обращаетесь именно к ноду!
    Из-за приведенных особенностей часто возникают проблемы с пространствами имен. Я часто путаю Point из Динамо и Point, которую создал в коде посредством АПИ. Как по мне, то Питон в Динамо не достаточно “инкапсулирован” от самого Динамо. Проблемы с пространствами имен встречаются постоянно. Я бы хотел, чтоб работая в Питоне, мы пользовались только методами Питона, а на методы Динамо ссылались как-то по другому. Хотя, думаю, это тоже большой вопрос для программистов.

    #7894 Score: 3
    ИваСерж
    Хранитель
    134 pts

    Могу только на питоне.
    В ИН0 – подаем список панелей
    В ИН1- подаем список координат.

    На выходе отсортированные панели.

    panelsList = IN[0]
    coordZlist = IN[1]

    ziped = zip(panelsList,coordZlist)
    ziped.sort(key=lambda x: x[1])
    outlist = [i[0] for i in ziped]

    OUT = outlist

    #8673 Score: 3
    ИваСерж
    Хранитель
    134 pts

    У нас не 3 питон, а 2.7
    я бы написал через генератор списков
    a = [1,3,5,7]
    b = [i*2 for i in a]
    OUT = b

    Можно через лямбду и мап
    a = [1,3,5,7]
    func = lambda x: x*2
    b = map(func, a)
    OUT = b

    #9292 Score: 3
    ИваСерж
    Хранитель
    134 pts

    Задача моего скрипта – делить существующие лотки на лотки стандартной длинны 1.5 м.
    Для этого я отфильтровываю все лотки, которые короче 1.5 м
    Затем вычисляю точки для новых лотков.
    Удаляю старые лотки.
    По точкам черчу новые лотки.
    Новые лотки соединяю. При этом автоматически воссоздаются коннекторы.
    Скрипт полностью рабочий.
    https://www.dropbox.com/s/f4vdwdur1b18abs/CableTrayDivide.zip?dl=0

    П.С. код, конечно, не очень удачный… Скрипт 16 года) Читаю код и хочу его теперь полностью переписать)

    #8700 Score: 3
    ИваСерж
    Хранитель
    134 pts

    http://dynamobim.ru/cmdownloads/%d1%8d%d0%bb%d0%b5%d0%ba%d1%82%d1%80%d0%be%d1%82%d0%b5%d1%85%d0%bd%d0%b8%d1%87%d0%b5%d1%81%d0%ba%d0%b8%d0%b9-%d1%80%d0%b0%d1%81%d1%87%d1%91%d1%82/

    Закончил обещаный скрипт по расчёту электрики. Тест-проект прикладываю. Записывать видео лень. Кому надо – спрашивайте. Скрипт написан под мой собственный БИМ стандарт. Прошел тесты на небольших проектах, но глобально не проверялся.

    #4234 Score: 3
    ИваСерж
    Хранитель
    134 pts

    Пример с динамо скриптом

    http://dynamobim.ru/cmdownloads/%D1%80%D0%B0%D1%81%D1%87%D1%91%D1%82-%D1%8D%D0%BB%D0%B5%D0%BA%D1%82%D1%80%D0%B8%D1%87%D0%B5%D0%BA%D0%B8%D1%85-%D0%BF%D0%B0%D1%80%D0%B0%D0%BC%D0%B5%D1%82%D1%80%D0%BE%D0%B2-%D1%81%D0%BE%D0%B7%D0%B4/

    Видео как работает. Правда, до конца так и не записал из-за отсутсвтия интереса.
    https://www.youtube.com/watch?v=-OgdSa-tMO0&list=PLXoMzi7DFVEZ9LfSdxDtba6bFMjA2d7vq

    На данный момент переработана  рассчётная часть скрипта. Добавлены контакторы и т.п.
    Не доделанными остаются 2Д  – пока размещаю схемы в модели, а не в чертежном виде. Но, как дойдут руки, доделаю.

    #8310 Score: 2
    ИваСерж
    Хранитель
    134 pts

    Мы говорим о марках или о самих трубах?
    Труба это не семейство (не Фемели инстанс).
    Очевидно, нет у трубы FamilyInstance.Type

    Зато у трубы есть PypeType
    В динамо есть даже нод GetPypeType

    Возможно, подтолкнет на какие-то идеи по замене трубы.

    А вот и пример скрипта который соединяет 2 любые трубы и вставляет фитинги по умолчанию.
    Проверил. У меня скрипт работает в 2019.

    АвтоСоединение
    Скрипт лежит у меня на дропбоксе пока мне не надоест.
    Если удалю и кому-то нужно будет – пишите в личку.

    #9752 Score: 2
    ИваСерж
    Хранитель
    134 pts

    Действительно, такая проблема есть.
    Я решил задачу определения коннектора по тому, ссылается ли этот коннектор на другие коннекторы или нет.
    Если не ссылается, то коннектор ни к чему не подключен.

    connector.AllRefs – выдаст коннекторы, с которыми связан. Иначе список будет пустой.
    Получается, так можно найти принадлежность к сети. Код ниже проверил на простом семействе. Прелагаю пример ниже.

    https://pastebin.com/HWeWmtcA

    #7419 Score: 2
    ИваСерж
    Хранитель
    134 pts

    Вопрос ещё актуален? Написал какраз работающий скрипт по вопросу. Могу помочь, если что.
    https://pastebin.com/rLDSg975

    #5936 Score: 2
    ИваСерж
    Хранитель
    134 pts

    Писал для Ревита 15. В 17 не тестил

    https://www.dropbox.com/s/tr3m0u6fkzmenhy/2016.08.05%20%D0%A1%D0%BE%D0%B5%D0%B4%D0%B8%D0%BD%D0%B5%D0%BD%D0%B8%D0%B5%20%D1%82%D1%80%D1%83%D0%B1%D1%8B.rar?dl=0

    В 17 Ревите нет метода NewPipeCreate.
    Надо использовать другой метод. Почитал в хелпе
    http://www.revitapidocs.com/2017/04817280-4044-112c-d229-59e8a50b1c95.htm

    Общий принцип – самый большой участок кода – рассчет точек, по которым будут строиться новые элементы. Посоздавать по этим точкам трубы и фитинги – дело методов и, как по мне, не является интересным. Дак вот: сначала рассчитываем точки “маршрута”, потом записываем этот маршрут в лист и запихиваем их в нод, который перечисляя эти точки в цикле строит трубы. После создания труб берем с них коннекторы и соединяем между собой фитингами.

    #7116 Score: 2
    ИваСерж
    Хранитель
    134 pts

    Код по ссылке.
    Прошу обратить внимание, я складываю стринг со стрингом.

    https://pastebin.com/GLzu3eNh

    #7864 Score: 2
    ИваСерж
    Хранитель
    134 pts

    К сожалению, Динамо не обладает особой гибкостью. Стены – это встроенные семейства. И получив такую ошибку я понял, что скорее всего нод не может найти это системное семейство. Через 10 секунд поисков я нашел нод WallType.ByName – работает со стенами. Также есть FloorType.ByName…
    Вывод – универсального решения нет (что странно).
    С выбором типов любого элемента нет проблем через АПИ (Питон)

    П.С.
    Почекал лукапом проекты. Действительно, типы семейств хранятся в разных типах объектов.
    Все обычные семейства это объект класса “FamilySymbol”
    У встроенных семейств свои классы для хранения типов.
    WallType, FloorType, CableTrayType и т.п.
    Динамо-нод FamilyType.ByName вытягивает только “FamilySymbol”. Метод АПИ GetTypeID – универсален и может получать доступ к любым объектам, описывающим типы.

    #8365 Score: 2
    ИваСерж
    Хранитель
    134 pts

    https://www.dropbox.com/s/f4vdwdur1b18abs/CableTrayDivide.zip?dl=0

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

    Округление делается в спецификации а не скриптом, поэтому я не заморачивался.

    #7192 Score: 2
    ИваСерж
    Хранитель
    134 pts

    1. Методы из АПИ выбрать напрямую нельзя. “Выбор” по нормальному, называется “перезагрузка метода”. работает так: в метод по очереди запихивается объект. Если первый метод отработал с ошибкой – объект запихивается во второй метод. И так до тех пор, пока что-то не отработает. Если ни один метод не отработал правильно – выдается ошибка.

    2. Из п.1 следует, что для начала нужно привести в порядок объекты, которые подаем в метод. В приведенном на скрине скрипте я сразу вижу ошибки в типах данных, которые подаются в метод. Каждую из ошибок надо рассматривать отдельно и очень внимательно.
    2.1 список polycurve должен быть не списком, а коллекцией из .Net Я тут недавно писал о том, как преобразовать список в коллекцию.
    2.2 Level – прошу не забывать, что на входе в нод залетает “Динамовский” объект. Его надо развернуть. Для получения “чистого” объекта применяем UnwrapElement
    2.3 direct – а вот тут не знаю, что на вводе (надо смотреть скрипт). Скорее всего на вводе объект Point, а метод кушает объект ХYZ (оказывается они разные точка и этот ХУЗ не одно и то же.) . Используем банальное преобразование  ХYZ(Point.X, Point.Y, Point.Z).

    Вывод. Надо привести в порядок объекты, которые подаем в метод. Скорее всего, и дальше будут какие-то ошибки, но прежде всего надо решить очевидные проблемы.

Просмотр 15 сообщений - с 1 по 15 (из 98 всего)