百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

BIMBase之python建模宝典:双坡屋顶

off999 2024-11-24 20:12 33 浏览 0 评论

BIMBase自从2021年发布以来获得了众多关心国产BIM和业务数字化转型的圈内老法师的关注,除了是国内首款完全自主知识产权的的BIMBase系统,实现建筑信息模型(BIM)关键核心技术自主研发安全可控。

同时开创了BIM X PYthon的技术跨界混搭风,得以让建模可以通过快速编程实现。


So!

BIMBase团队为了在功能和场景上

帮助大家了解BIMBase

学习建模小技巧

开设了技术专栏

【BIMBase之python建模宝典】

今日分享第十弹


生活中的屋顶大多为双坡,部分由于采光要求会有主次屋顶之分。如何根据对称性和三维斜面拉伸高效运用Python参数化建模创建双坡屋顶?今天,来带你揭晓答案!

图 1 双坡屋顶


建模方法

BIMBase双坡屋顶

引用pyp3d,定义参数,变量赋值(既然有主次屋顶之分必然须定义两部分各自参数!)

class 双坡屋顶(Component):

def __init__(self):

Component.__init__(self)

self['双坡屋顶'] = Attr(None, show = True)

self['屋顶坡度'] = Attr(30.0, obvious = True)

self['屋顶厚度'] = Attr(295.0, obvious = True)

self['屋顶高差'] = Attr(231.0, obvious = True, readonly = True)

# 主屋顶

self['主屋顶宽度'] = Attr(2000.0, obvious = True, group = '主屋顶')

self['主屋顶长度'] = Attr(9000.0, obvious = True, group = '主屋顶')

# 次屋顶

self['次屋顶宽度'] = Attr(1600.0, obvious = True, group = '次屋顶')

self['次屋顶长度'] = Attr(1600.0, obvious = True, readonly = True, group = '次屋顶')

self['次屋顶方位'] = Attr('右', combo = ['右', '左'], obvious = True, group = '次屋顶')

self['次屋顶间距'] = Attr(4000.0, obvious = True, group = '次屋顶')

self.replace()

@export

def replace(self):

# 主屋顶

mainRoofWidth = self['主屋顶宽度']

mainRoofLength = self['主屋顶长度']

# 次屋顶

viceRoofWidth = self['次屋顶宽度']

self['次屋顶长度'] = viceRoofWidth

viceRoofLength = self['次屋顶长度']

viceRoofSpace = self['次屋顶间距']

# 公有属性

roofSlope = self['屋顶坡度']

roofThickness = self['屋顶厚度']

self['屋顶高差'] = (mainRoofWidth-viceRoofWidth)*tan(roofSlope/180*pi)

roofLevDiff = self['屋顶高差']


主屋顶

运用Extrusion函数直接对三维斜面leftRoof_sec进行厚度方向的拉伸,构造左侧主屋顶,根据对称性原理运用mirror函数构造对称部分(一定注意对称轴的方位呀!)最后只需小小组合便成功得到主屋顶啦。

leftRoof_sec = [Vec3(0, -roofLength/2, 0),

Vec3(roofWidth, -roofLength/2,

roofWidth*tan(slope/180*pi)),

Vec3(roofWidth, roofLength/2,

roofWidth*tan(slope/180*pi)),

Vec3(0, roofLength/2, 0)]

leftRoof = trans(-roofWidth, 0, -roofWidth*tan(slope/180*pi))*\

Extrusion(leftRoof_sec, Vec3

(0, 0, -roofThickness/cos(slope/180*pi)))

rightRoof = mirror_yoz()*leftRoof

doublePitchRoof = unite(leftRoof, rightRoof)

图2 左主屋顶

图3 右主屋顶

图4 主屋顶


③ 次屋顶

为提高代码复用能力,本文将生成次屋顶的过程存放于一个自定义函数中。

def doublePitchRoof (roofWidth, roofLength, roofThickness, slope, isMain = True):

相比主屋顶,次屋顶的构造有一定的难度,需要细致分析。首先运用上述主屋顶的方式代入次屋顶的相关变量,得到一个形状与主屋顶类似的构件,运用布尔减得到双坡屋顶中次屋顶部分。

if not isMain:

lengthSlope = trans(0, roofLength/2, 0)*\

Sweep(rotx(slope/180*pi)*\

Section(scale(4*sin(slope/180*pi)/

cos(slope/180*pi)*roofWidth)*Arc()),

Line(Vec3(0, 0, 0), Vec3(0, 2*roofLength, 0)))

doublePitchRoof = doublePitchRoof-lengthSlope

hollow = Extrusion([Vec3(-roofWidth, -roofLength/2, -roofWidth*tan(slope/180*pi)/

-roofThickness/cos(slope/180*pi)),

Vec3(0, -roofLength/2,

-roofThickness/cos(slope/180*pi)),

Vec3(roofWidth, -roofLength/2,

-roofWidth*tan(slope/180*pi)/

-roofThickness/cos(slope/180*pi))],

Vec3(0, roofLength, 0))

return doublePitchRoof, hollow # 返回包含次屋顶和次屋顶应减切区域的列表

return doublePitchRoof



图5 布尔减


镜像组合

你以为到这就结束了?

千万别忘记次屋顶的方位问题,运用translate、rotate函数进行变位,再次使用mirror函数对称得到2号次屋顶,到此,次屋顶构造完成。通过doublePitchRoof函数返回的包含次屋顶屋面和次屋顶应该剪切区域的列表,得到布尔减后的主屋顶。

# 主屋顶

mainRoof = doublePitchRoof(mainRoofWidth, mainRoofLength, roofThickness, roofSlope)

# 次屋顶

viceRoof1 = trans(mainRoofWidth-viceRoofLength/2, viceRoofSpace/2, -roofLevDiff)*\

rotz(pi/2)*\

doublePitchRoof(viceRoofWidth, viceRoofLength, roofThickness, roofSlope, False)

if self['次屋顶方位'] == '左':

viceRoof1 = mirror_yoz()*viceRoof1

viceRoof2 = mirror_xoz()*viceRoof1

viceRoof = Combine(viceRoof1[0], viceRoof2[0])

mainRoof = mainRoof-viceRoof1[1]-viceRoof2[1]

self['双坡屋顶'] = Combine(mainRoof, viceRoof)

图6 旋转移动

镜像对称

图7 布尔减后主屋顶

图8 组合


方法总结

BIMBase双坡屋顶

1. Extrusion可以对三维面进行拉伸;

2. 镜像函数mirror仅需一步即可实现构件的对称布置。

正在学习BIMBase-Python的小伙伴,你还在犹豫什么?还不赶快动手试试?

相关推荐

邮件服务器(hmailserver搭建邮件服务器)

电子邮件服务器名称:比如添加的是网易邮箱帐号在“接收邮件(pop、IMAP或HTTP)服务器:”字段中输入pop.163.com。在“发送邮件服务器(SMTP):”字段中输入smtp.163.com...

win7蓝屏0x0000000a(win7蓝屏代码0x000000f4)

电脑蓝屏代码0x0000000a的原因以及解决办法如下:1、在BIOS界面内,进入“Intogratedperipherals”选项里把“SATAConfiguration”项的值改成IDE。&...

手机看nwd格式的3d图软件(手机看3d图片)

NWD只有具备NavisWorksPublisher许可才能保存NWD文件。这种文件格式存储NWF文件格式存储的所有NavisWorks特定数据,外加模型的几何图形。NWD文件一般比原始的CAD文件...

windows系统正版(win10正版系统)

WINDOWS激活了不一定是正版,可以使用以下方法验证:"开始"菜单——"运行"中输入:1、slmgr.vbs-dli显示:操作系统版本、部分产品密钥、许可证状态...

创新声卡驱动安装教程(创新声卡7.1驱动安装)

1、准备工作:准备好声卡驱动安装文件,根据自己计算机操作系统的不同而选择不同的版本2、双击安装文件,根据弹出的提示进行操作,进行安装,可以选择安装至默认位置,安装过程中会出现若干设置,最好按照制造厂商...

win10进入安全模式黑屏(win10进安全模式黑屏什么都不显示)

正常情况下进入“安全模式”屏幕是黑色的,没有壁纸。并且,与显卡,显示器没有任何关系。正常模式比安全模式多加载了很多启动,视频模式有所改变。如果出现异常,则有可能是以下问题引起:1、正常模式下...

问7升级win10(win 7升win 10)

Windows7系统如何升级为win10。嗯,这个是需要重新安装操作系统的。请在安装前先预备好备份好windows7系统下面你自己的个人数据备份到自己的移动硬盘上面。然后通过USB导的方式进行安装,...

windows中文叫什么(win的中文是什么)

windows是窗口的意思,翻译到中文可以是窗户的意思。现在windows的意思大多用在PC领域,泛指微软出品的电脑、手机操作系统。windows操作系统业可以叫做视窗操作系统、可视化图形界面操作系统...

win7系统激活工具下载免费(win7激活工具免费版)

KMSpico是一个非常好用的Win7系统激活工具。它简单易用,只需一步操作即可激活系统,无需复杂的设置和操作。同时,它支持离线激活和在线激活两种方式,让用户可以根据自己的需求选择使用。此外,KMSp...

tenda路由器怎么设置网速快(tendawifi怎么设置网速快)

tenda设置网速最快方法如下:1.登入无线路由器;在浏览器地址输入192.168.0.1;无线路由器进入无线路由器控制界面几乎都是这个地址;原始密码admin。2.接着点击“高级设置”或者页面右上角...

功能最全的pe系统(pe系统功能介绍)

1、Windows预安装环境,是带有有限服务的最小Win32子系统,基于以保护模式运行的WindowsXPProfessional及以上内核。它包括运行Windows安装程序及脚本、连接网络共享、...

华为鸿蒙操作系统下载(华为鸿蒙电脑操作系统下载)

鸿蒙系统可以下载拼多多,但需要注意的是,目前拼多多官方并未推出面向鸿蒙系统的专门版本,所以需要通过安装第三方应用市场或者通过APK安装包的方式才能在鸿蒙系统上安装使用。此外,由于鸿蒙系统和拼多多应用的...

系统iso怎么安装(系统iso怎么安装应用)

ISO系统安装详细教程步骤如下:1.准备所需材料:一台符合系统要求的计算机、ISO系统文件、可启动的USB驱动器或光盘、系统激活密钥(如果需要的话)。2.制作启动盘:如果你使用USB驱动器作为启动...

在微软官网下载win10(在微软官网下载vc要钱吗)

windows1021H2这可能意味着您的电脑不满足下载或安装升级到Windows11的最低要求。如果您的电脑不符合要求,您将无法下载或安装Windows11。此外,这也可能表示电脑上的驱动程序...

dnf安全模式怎么解除最新办法

一、我们需要登录微信,然后使用微信关注“腾讯游戏安全中心”。最后进入公众号页面。二、进入公众号以后,我们点击游戏账号绑定。进入账号绑定页面。绑定我们自己的个人游戏账号。三、进入游戏账号绑定操作页面以后...

取消回复欢迎 发表评论: