亚洲免费av电影一区二区三区,日韩爱爱视频,51精品视频一区二区三区,91视频爱爱,日韩欧美在线播放视频,中文字幕少妇AV,亚洲电影中文字幕,久久久久亚洲av成人网址,久久综合视频网站,国产在线不卡免费播放

        ?

        淺談VB.net結(jié)合InventoriLogic在工程中的應(yīng)用

        2016-09-05 08:55:08梁凱旋
        黑龍江水利科技 2016年5期
        關(guān)鍵詞:參數(shù)表中墩弧形

        梁凱旋

        (新疆水利水電勘測(cè)設(shè)計(jì)研究院,烏魯木齊 830000)

        ?

        淺談VB.net結(jié)合InventoriLogic在工程中的應(yīng)用

        梁凱旋

        (新疆水利水電勘測(cè)設(shè)計(jì)研究院,烏魯木齊 830000)

        利用VB.net面向?qū)ο蟮膹?qiáng)大功能和內(nèi)嵌的iLogic對(duì)Inventor進(jìn)行二次開(kāi)發(fā),創(chuàng)建自定義用戶界面,使交互起來(lái)更方便、更直觀, 實(shí)現(xiàn)自身fx參數(shù)表不能實(shí)現(xiàn)的功能,從而在實(shí)際工作中提高效率。文章介紹了VB.net結(jié)合InventoriLogic在工程中的應(yīng)用。

        VB.net;Inventor;iLogic;水利工程;結(jié)構(gòu)模型;水力學(xué)計(jì)算

        0 引 言

        VB.net語(yǔ)言繼承了VB的特點(diǎn),即簡(jiǎn)單易學(xué),功能強(qiáng)大,容易上手,開(kāi)發(fā)周期短 ,而且VB.net最大的優(yōu)點(diǎn)是完全面向?qū)ο螅踔量梢耘cC++相媲美,目前眾多行業(yè)軟件比如AutoCad,Inventor,Civil3D等都提供.Net API二次開(kāi)發(fā)接口,以便豐富自己的函數(shù)庫(kù),是目前眾多流行軟件的比較理想的二次開(kāi)發(fā)語(yǔ)言,此外VB.net的開(kāi)發(fā)環(huán)境為微軟強(qiáng)大的Visual Studio(VS)集成開(kāi)發(fā)平臺(tái),借助VS提供的強(qiáng)大的編輯和錯(cuò)誤調(diào)試功能,使得開(kāi)發(fā)過(guò)程能夠快速高效的完成[1]。iLogic是嵌入到Inventor中的一個(gè)規(guī)則驅(qū)動(dòng)程序,通過(guò)設(shè)定一些規(guī)則來(lái)達(dá)到驅(qū)動(dòng)模型進(jìn)行修改的目的,只需要寫一些簡(jiǎn)單的代碼即可完成一些繁瑣的步驟,比較簡(jiǎn)單易學(xué)。

        1 VB.net和iLogic的結(jié)合

        通過(guò)VB.net和iLogic的結(jié)合,發(fā)揮各自的優(yōu)勢(shì),來(lái)實(shí)現(xiàn)一些特定的功能,減少繁瑣的步驟,提高設(shè)計(jì)的效率。

        1.1各自的功能

        在VB.net中,主要利用面向?qū)ο蠹夹g(shù)來(lái)完成自定義交互界面的創(chuàng)建、一些計(jì)算方法或函數(shù)的創(chuàng)建、錯(cuò)誤的處理等,最后將其封裝成一個(gè)叫做.dll的文件,這個(gè).dll文件就可以被iLogic調(diào)用。

        iLogic 起到中間傳遞的作用,主要完成Inventor模型參數(shù)的傳遞和接收。工作原理是首先將模型中參數(shù)名稱傳遞給交互給界面,然后通過(guò)窗體內(nèi)部的計(jì)算,最后將計(jì)算的值進(jìn)行接收并賦值給inventor模型中對(duì)應(yīng)的參數(shù)名稱,從而驅(qū)動(dòng)模型的修改。

        1.2如何結(jié)合

        首先在iLogic環(huán)境中引用VB.net生成的.dll程序,其次將inventor模型中fx參數(shù)表中的參數(shù)名稱傳遞到交互界面中,然后通過(guò)調(diào)用封裝在里面的函數(shù)或方法,完成一些特定的計(jì)算或分析,并返回需要的參數(shù),然后將參數(shù)施加給模型即可[2]。

        2 在水工結(jié)構(gòu)中的應(yīng)用

        2.1分析并創(chuàng)建水工結(jié)構(gòu)模型

        分析模型由哪幾部分構(gòu)成,需要哪些參數(shù),根據(jù)部位一一列舉出來(lái)。比如:閘底板長(zhǎng),閘底板寬,閘底板厚,邊墩厚,中墩厚,閘墩高,孔數(shù),單孔寬,檢修門槽寬,檢修門槽深等等(見(jiàn)圖1),然后創(chuàng)建水閘模型。其中參數(shù)名稱盡量用英文表示,這樣做的目的主要是為了和VB.net代碼中的參數(shù)名稱進(jìn)行相對(duì)應(yīng)。

        2.2定義用戶參數(shù)

        打開(kāi)inventor的fx參數(shù)表,將前面列舉出來(lái)的參數(shù)依次添加到表中,并賦初始值,然后在注釋列中添加中文解釋,以方便后期進(jìn)行檢查。見(jiàn)圖2。

        圖1 水閘結(jié)構(gòu)模型預(yù)覽

        圖2 fx自定義用戶參數(shù)列表

        2.3將自定義參數(shù)賦予模型

        將fx中的定義好的參數(shù)賦給模型參數(shù),以便對(duì)模型進(jìn)行驅(qū)動(dòng)。見(jiàn)圖3。

        圖3 fx模型參數(shù)列表

        2.4VB.net中的主要代碼

        '定義公共變量,變量名稱要和前面定義的fx用戶參數(shù)名稱保持一致。

        Public Class MainForm

        Public BaseboardLength As Double'底板長(zhǎng)

        Public BaseboardThickness As Double '底板厚

        Public SingleOrificeWidth As Double '單孔寬

        Public OrificeCount As Integer '孔數(shù)

        Public BaseboardWidth As Double '底板寬

        Public MidPierThickness As Double '中墩厚

        Public OutsidePierThickness As Double '邊墩厚

        Public PierHigh As Double '閘墩高

        Public RepairGateGrooveWidth As Double '檢修門槽寬

        Public RepairGateGrooveDepth As Double '檢修門槽深

        Public RepairGateDistanceToUpper As Double '檢修門槽中心線距離上游距離

        Public WorkingGateGrooveWidth As Double '弧形門槽寬

        Public WorkingGateGrooveDepth As Double '弧形門槽深

        Public ArticulatedPositionX As Double '支鉸位置X

        Public ArticulatedPositionY As Double '支鉸位置y

        Public WorkingGateGrooveRadius As Double '弧形門槽半徑

        Public TrafficBridgeWidth As Double '交通橋?qū)?/p>

        Public TrafficBridgeThickness As Double '交通橋厚

        Public WaterGateLo As Double '水閘凈寬

        Public WaterQ As Double '水閘過(guò)流量

        '初始化函數(shù)

        Private Sub Initialize()

        BaseboardLengthTxtbox.Text = BaseboardLength.ToString

        BaseboardThicknessTxtbox.Text = BaseboardThickness.ToString

        BaseboardWidthTxtbox.Text = BaseboardWidth.ToString

        OrificeCountTxtbox.Text = OrificeCount.ToString

        SingleOrificeWidthTxtbox.Text = SingleOrificeWidth.ToString

        OutsidePierThicknessTxtbox.Text = OutsidePierThickness.ToString

        MidPierThicknessTxtbox.Text = MidPierThickness.ToString

        PierHighTxtbox.Text = PierHigh.ToString

        RepairGateGrooveWidthTxtbox.Text = RepairGateGrooveWidth.ToString

        RepairGateGrooveDepthTxtbox.Text = RepairGateGrooveDepth.ToString

        RepairGateDistanceToUpperTxtbox.Text= epairGateDistanceToUpper.ToString

        WorkingGateGrooveWidthTxtbox.Text = WorkingGateGrooveWidth.ToString

        WorkingGateGrooveDepthTxtbox.Text = WorkingGateGrooveDepth.ToString

        ArticulatedPositionXTxtbox.Text = ArticulatedPositionX.ToString

        ArticulatedPositionYTxtbox.Text = ArticulatedPositionY.ToString

        WorkingGateGrooveRadiusTxtbox.Text = WorkingGateGrooveRadius.ToString

        TrafficBridgeWidthTxtbox.Text = TrafficBridgeWidth.ToString

        TrafficBridgeThicknessTxtbox.Text = TrafficBridgeThickness.ToString

        End Sub

        '當(dāng)文本框的內(nèi)容更新后,重新給變量賦值

        Private Sub UpdateValues()

        BaseboardLength = Val(BaseboardLengthTxtbox.Text)

        BaseboardThickness = Val(BaseboardThicknessTxtbox.Text)

        BaseboardWidth = Val(BaseboardWidthTxtbox.Text)

        OrificeCount = Val(OrificeCountTxtbox.Text)

        SingleOrificeWidth = Val(SingleOrificeWidthTxtbox.Text)

        OutsidePierThickness = Val(OutsidePierThicknessTxtbox.Text)

        MidPierThickness = Val(MidPierThicknessTxtbox.Text)

        PierHigh = Val(PierHighTxtbox.Text)

        RepairGateGrooveWidth = Val(RepairGateGrooveWidthTxtbox.Text)

        RepairGateGrooveDepth = Val(RepairGateGrooveDepthTxtbox.Text)

        RepairGateDistanceToUpper = Val(RepairGateDistanceToUpperTxtbox.Text)

        WorkingGateGrooveWidth = Val(WorkingGateGrooveWidthTxtbox.Text)

        WorkingGateGrooveDepth = Val(WorkingGateGrooveDepthTxtbox.Text)

        ArticulatedPositionX = Val(ArticulatedPositionXTxtbox.Text)

        ArticulatedPositionY = Val(ArticulatedPositionYTxtbox.Text)

        WorkingGateGrooveRadius = Val(WorkingGateGrooveRadiusTxtbox.Text)

        TrafficBridgeWidth = Val(TrafficBridgeWidthTxtbox.Text)

        TrafficBridgeThickness = Val(TrafficBridgeThicknessTxtbox.Text)

        End Sub

        '重寫父類 onload 方法

        Protected Overrides Sub OnLoad(e As EventArgs)

        Initialize()

        End Sub

        '重寫父類的onFormClosed的方法

        Protected Overrides Sub OnFormClosed(e As FormClosedEventArgs)

        UpdateValues()

        End Sub

        '包含一些約束判斷條件,使所有的數(shù)據(jù)都在和合理有效的范圍之內(nèi),以防止模型出現(xiàn)錯(cuò)誤。

        '門槽深度和邊墩厚的判斷,包括檢修門槽和弧形門槽

        Private Sub RepairGateGrooveDepthTxtbox_Leave(sender As Object,e As EventArgs) Handles RepairGateGrooveDepthTxtbox.Leave

        If Not (Val(RepairGateGrooveDepthTxtbox.Text) < Val(OutsidePierThicknessTxtbox.Text)) Then

        MsgBox("檢修門槽的深度過(guò)大,已超過(guò)邊墩厚")

        RepairGateGrooveDepthTxtbox.SelectAll()

        End If

        If Not (Val(RepairGateGrooveDepthTxtbox.Text) < Val(MidPierThicknessTxtbox.Text)) Then

        MsgBox("檢修門槽的深度過(guò)大,已超過(guò)中墩厚")

        RepairGateGrooveDepthTxtbox.SelectAll()

        End If

        End Sub

        Private Sub WorkingGateGrooveDepthTxtbox_Leave(sender As Object,e As EventArgs) Handles WorkingGateGrooveDepthTxtbox.Leave

        If Not (Val(WorkingGateGrooveDepthTxtbox.Text) < Val(OutsidePierThicknessTxtbox.Text)) Then

        MsgBox("弧形門槽的深度過(guò)大,已超過(guò)邊墩厚")

        WorkingGateGrooveDepthTxtbox.SelectAll()

        End If

        If Not (Val(WorkingGateGrooveDepthTxtbox.Text) < Val(MidPierThicknessTxtbox.Text)) Then

        MsgBox("弧形門槽的深度過(guò)大,已超過(guò)中墩厚")

        WorkingGateGrooveDepthTxtbox.SelectAll()

        End If

        End Sub

        2.5加載到inventor中進(jìn)行應(yīng)用

        將前面創(chuàng)建好的窗體及代碼生成WaterGate.dll文件,并將該文件放到模型的同一目錄下,然后打開(kāi)規(guī)則瀏覽器,創(chuàng)建一個(gè)規(guī)則,把下面的代碼粘貼進(jìn)去即可。

        AddReference "WaterGate.dll"

        localTrigger = iTrigger0

        Using dlg As New woxing1987.MainForm

        dlg.BaseboardLength = BaseboardLength

        dlg.BaseboardThickness = BaseboardThickness

        dlg.SingleOrificeWidth = SingleOrificeWidth

        dlg.OrificeCount = OrificeCount

        dlg.BaseboardWidth = BaseboardWidth

        dlg.MidPierThickness = MidPierThickness

        dlg.OutsidePierThickness = OutsidePierThickness

        dlg.PierHigh = PierHigh

        dlg.RepairGateGrooveWidth = RepairGateGrooveWidth

        dlg.RepairGateGrooveDepth = RepairGateGrooveDepth

        dlg.RepairGateDistanceToUpper = RepairGateDistanceToUpper

        dlg.WorkingGateGrooveWidth = WorkingGateGrooveWidth

        dlg.WorkingGateGrooveDepth = WorkingGateGrooveDepth

        dlg.ArticulatedPositionX = ArticulatedPositionX

        dlg.ArticulatedPositionY = ArticulatedPositionY

        dlg.WorkingGateGrooveRadius = WorkingGateGrooveRadius

        dlg.TrafficBridgeWidth = TrafficBridgeWidth

        dlg.TrafficBridgeThickness = TrafficBridgeThickness

        Dim i As Integer = dlg.ShowDialog()

        If i <> vbOK Then Return

        BaseboardLength =dlg.BaseboardLength

        BaseboardThickness =dlg.BaseboardThickness

        SingleOrificeWidth =dlg.SingleOrificeWidth

        OrificeCount =dlg.OrificeCount

        If OrificeCount=1 Then

        ' ***中墩陣列***

        Feature.IsActive("中墩陣列") = False

        ' ***中墩弧形門槽拉伸2***

        Feature.IsActive("中墩弧形門槽拉伸2") = False

        ' ***中墩弧形門槽拉伸1***

        Feature.IsActive("中墩弧形門槽拉伸1") = False

        ' ***中墩起始拉伸***

        Feature.IsActive("中墩起始拉伸") = False

        ElseIfOrificeCount > 1 Then

        '***中墩起始拉伸***

        Feature.IsActive("中墩起始拉伸") = True

        ' ***中墩弧形門槽拉伸1***

        Feature.IsActive("中墩弧形門槽拉伸1") = True

        ' ***中墩弧形門槽拉伸2***

        Feature.IsActive("中墩弧形門槽拉伸2") = True

        ' ***中墩陣列***

        Feature.IsActive("中墩陣列") = True

        End If

        BaseboardWidth =dlg.BaseboardWidth

        MidPierThickness =dlg.MidPierThickness

        OutsidePierThickness =dlg.OutsidePierThickness

        PierHigh =dlg.PierHigh

        RepairGateGrooveWidth =dlg.RepairGateGrooveWidth

        RepairGateGrooveDepth =dlg.RepairGateGrooveDepth

        RepairGateDistanceToUpper =dlg.RepairGateDistanceToUpper

        WorkingGateGrooveWidth =dlg.WorkingGateGrooveWidth

        WorkingGateGrooveDepth =dlg.WorkingGateGrooveDepth

        ArticulatedPositionX =dlg.ArticulatedPositionX

        ArticulatedPositionY =dlg.ArticulatedPositionY

        WorkingGateGrooveRadius =dlg.WorkingGateGrooveRadius

        TrafficBridgeWidth =dlg.TrafficBridgeWidth

        TrafficBridgeThickness =dlg.TrafficBridgeThickness

        End Using

        iLogicVb.UpdateWhenDone = True

        運(yùn)行效果見(jiàn)圖5,當(dāng)更改文本框中的值并點(diǎn)擊確定按鈕后,inventor中的模型會(huì)立即發(fā)生更改。

        圖5 在inventor中運(yùn)行

        3 應(yīng)用擴(kuò)展

        在自定義用戶界面中可以包含一些簡(jiǎn)單的水力學(xué)計(jì)算,這樣就可以不需要通過(guò)Excel計(jì)算,就可以在同一個(gè)界面內(nèi)完成,另外還可以利用VS集成開(kāi)發(fā)平臺(tái)構(gòu)建更復(fù)雜,更強(qiáng)大,更友好的交互界面,融合一些材料計(jì)算、結(jié)構(gòu)計(jì)算等常規(guī)的力學(xué)內(nèi)容,使得自定義用戶界面元素更豐富,功能更強(qiáng),甚至還可以結(jié)合數(shù)據(jù)庫(kù)進(jìn)行更深層次的二次開(kāi)發(fā)。

        4 結(jié) 語(yǔ)

        總之通過(guò)VB.net創(chuàng)建自定義用戶界面,不僅可以達(dá)到界面友好美觀,而且可以很方便的同用戶進(jìn)行交互,比f(wàn)x參數(shù)列表的界面更加友好,更加直觀,同時(shí)可以擴(kuò)展更多的專業(yè)功能,這一點(diǎn)是f(x)參數(shù)表不能達(dá)到的。

        [1]紐瑟姆.Visual Basic 2012入門經(jīng)典[M].北京:清華大學(xué)出版社,2013:26-38.

        [2]陳伯雄,馮偉.Inventor-iLogic程序設(shè)計(jì)解析與實(shí)戰(zhàn)[M].北京:化學(xué)工業(yè)出版社,2014:45-51.

        1007-7596(2016)05-0139-04

        2016-03-15

        梁凱旋(1987-),男,河南許昌人,助理工程師,從事水利工程專業(yè)。

        TU415

        B

        猜你喜歡
        參數(shù)表中墩弧形
        V形墩連續(xù)剛構(gòu)橋設(shè)計(jì)參數(shù)研究
        鋼結(jié)構(gòu)有限元參數(shù)化分析系統(tǒng)研究
        為什么彩虹是弧形的
        彩虹為什么是弧形的
        淺議鋼箱梁T構(gòu)轉(zhuǎn)體橋中墩施工技術(shù)
        建筑與裝飾(2020年5期)2020-05-08 08:29:04
        清河水庫(kù)第二泄洪洞進(jìn)口閘中墩體型優(yōu)化研究
        WPS在成形管生產(chǎn)過(guò)程中的運(yùn)用
        EXCEL在調(diào)度自動(dòng)化系統(tǒng)數(shù)據(jù)庫(kù)維護(hù)中的應(yīng)用
        水閘中墩網(wǎng)?;炷恋氖┕ぜ夹g(shù)
        天上的彩虹為什么總是呈現(xiàn)弧形?
        河北遙感(2015年2期)2015-07-18 11:11:15
        丰满老熟妇好大bbbbb| 亚洲永久国产中文字幕| 亚洲精品无码永久在线观看 | 在线va免费看成| 亚洲天天综合色制服丝袜在线| 国产成人亚洲精品一区二区三区| 国产一区二区三区日韩精品| 蜜臀av 国内精品久久久| 精选麻豆国产AV| 久久免费看视频少妇高潮| 久久久99精品成人片| 国产亚洲精品久久久久婷婷瑜伽 | 亚洲综合免费在线视频| 自拍偷自拍亚洲精品第按摩| 欧洲熟妇色xxxx欧美老妇多毛 | 就去吻亚洲精品欧美日韩在线| 国产一区二区在线观看我不卡| 精品国产亚洲第一区二区三区| 大地资源在线观看官网第三页| 日韩毛片在线看| 性视频毛茸茸女性一区二区| 国产高清一区二区三区四区色| 欧美成人免费全部| 国产99页| 国产精品高清视亚洲一区二区| 国产太嫩了在线观看| 国产精品丝袜黑色高跟鞋| 久久婷婷国产五月综合色| 一本一道久久精品综合| 亚洲国产成人久久综合下载| 国产情侣一区在线| 日韩一二三四区在线观看| 一本精品99久久精品77| 国产黄色免费网站| 中文字幕久久人妻av| 一个人看的www片免费高清视频| 国产成人亚洲精品无码h在线| 国产V亚洲V天堂A无码| 国产麻豆久久av入口| 午夜精品久久久久久| 久久精品国产屋|