1

我正在尝试使用 RevitPythonshell 在 Revit 的 3D 视图中覆盖墙的图形。我设法使用 Python 节点在 Dynamo 中完成了这项工作。

到目前为止,我有以下代码;

import clr
clr.AddReference('ProtoGeometry')
from Autodesk.DesignScript.Geometry import *

clr.AddReference('RevitAPI')
import Autodesk
from Autodesk.Revit.DB import *

clr.AddReference('RevitServices')
import RevitServices
from RevitServices.Persistence import DocumentManager
from RevitServices.Transactions import TransactionManager 

from System.Collections.Generic import List


doc = DocumentManager.Instance.CurrentDBDocument

TransactionManager.Instance.EnsureInTransaction(doc)

walls = FilteredElementCollector(doc).OfCategory(BuiltInCategory.OST_Walls)
elements = walls.OfCategory(BuiltInCategory.OST_Walls).WhereElementIsNotElementType()


color = Autodesk.Revit.DB.Color(255,50,50)
ogs = OverrideGraphicSettings().SetProjectionFillColor(color)


for i in elements:
    doc.ActiveView.SetElementOverrides((i.Id), ogs)


TransactionManager.Instance.TransactionTaskDone()

当我在 RevitPythonShell 中运行它时,它什么也不做。我没有得到任何错误或任何东西。当我打印doc.ActiveView.SetElementOverrides((i.Id), ogs)它返回无。

我在这里想念什么?我在 Revit 中的 3D 视图中,这是活动视图。我正在开始和结束交易。

是 Dynamo 节点中 Python 节点中的代码有些相同。

4

2 回答 2

1

通过一些调整,您的代码可以工作:

import clr

clr.AddReference('RevitAPI') 
clr.AddReference('RevitAPIUI') 
from Autodesk.Revit.DB import * 
from Autodesk.Revit.UI import *

app = __revit__.Application
doc = __revit__.ActiveUIDocument.Document

elements = list(FilteredElementCollector(doc, doc.ActiveView.Id))

color = Color(255,50,50)
ogs = OverrideGraphicSettings().SetProjectionFillColor(color)

t = Transaction(doc, 'Color Walls')
t.Start()
try:
    for i in elements:
        if i.Category.Name == 'Walls':
            doc.ActiveView.SetElementOverrides((i.Id), ogs)
            print 'element overridden'
except Exception as e:
    print '- Failed to override -'
    print '- ' + str(e) + ' -'
t.Commit()
  • 当您将 a 传递View.Id给 时FilteredElementCollector,您会收集该视图中可见的所有内容
  • 在 Dynamo 的 RevitPythonShell 中,事务的工作方式略有不同,您可以在实际修改数据库的代码周围打开并关闭它们
  • 当您在事务中时,将代码包装在 try/except 块中是值得的,因为即使出现错误,您也需要完成事务
于 2017-12-22T19:52:30.697 回答
1

我设法以以下方式为不同类型的墙壁着色。

import clr 
clr.AddReference('RevitAPI') 
clr.AddReference('RevitAPIUI') 
import Autodesk
from Autodesk.Revit.DB import * 
from Autodesk.Revit.UI import *

from random import randint

app = __revit__.Application
doc = __revit__.ActiveUIDocument.Document

#elements = list(FilteredElementCollector(doc, doc.ActiveView.Id))
wall_collector = FilteredElementCollector(doc).OfCategory(BuiltInCategory.OST_Walls)
wall_instances = wall_collector.OfCategory(BuiltInCategory.OST_Walls).WhereElementIsNotElementType()



fill_patterns = FilteredElementCollector(doc).OfClass(FillPatternElement).WhereElementIsNotElementType().ToElements()

for i in fill_patterns:
    if i.Name == 'Solid fill':
        solid_fill = i.Id

element_list = []
element_name_list = []

for i in wall_instances:
    element_name_list.append(i.Name)
    element_list.append(i.Id)

wall_color_dict = {}
for i in set(element_name_list):
    wall_color_dict[i] = Color(randint(0,250), randint(0,250), randint(0,250))

t = Transaction(doc, 'Color Walls')

t.Start()

for i in wall_instances:
    for k, v in wall_color_dict.iteritems():
        if k == i.Name: 
            a=OverrideGraphicSettings().SetProjectionFillPatternId(solid_fill)
            b=OverrideGraphicSettings(a).SetProjectionFillColor(v)
            p = doc.ActiveView.SetElementOverrides(i.Id, a)
            c = doc.ActiveView.SetElementOverrides(i.Id, b)




t.Commit()

在运行脚本之前: 前

运行脚本后:

在此处输入图像描述

于 2018-01-03T12:47:26.470 回答