summaryrefslogtreecommitdiff
path: root/Connections/Shear/Finplate/Finplate0dot1.py
diff options
context:
space:
mode:
Diffstat (limited to 'Connections/Shear/Finplate/Finplate0dot1.py')
-rw-r--r--Connections/Shear/Finplate/Finplate0dot1.py938
1 files changed, 938 insertions, 0 deletions
diff --git a/Connections/Shear/Finplate/Finplate0dot1.py b/Connections/Shear/Finplate/Finplate0dot1.py
new file mode 100644
index 0000000..c8c539a
--- /dev/null
+++ b/Connections/Shear/Finplate/Finplate0dot1.py
@@ -0,0 +1,938 @@
+'''
+Created on 07-May-2015
+
+@author: deepa
+'''
+from PyQt4.QtCore import QString
+from PyQt4.QtGui import QMessageBox
+'''
+Created on 21-Aug-2014
+
+@author: deepa
+'''
+import sys
+from OCC import VERSION
+#from PyQt4 import QtGui,QtCore
+from ui_finPlate2 import Ui_MainWindow
+from model import *
+#from finPlateCalc import finConn
+from finplate_calc1 import finConn
+import yaml
+import pickle
+import logging
+#from exampleSimpleGUI import init_display
+from OCC.BRepAlgoAPI import BRepAlgoAPI_Fuse
+from OCC._Quantity import Quantity_NOC_RED,Quantity_NOC_BLUE1,Quantity_NOC_SADDLEBROWN
+from ISection import ISection
+import numpy
+from OCC.Graphic3d import Graphic3d_NOT_2D_ALUMINUM
+from weld import Weld
+from plate import Plate
+from bolt import Bolt
+from nut import Nut
+import os.path
+from utilities import osdagDisplayShape
+from OCC.Display.pyqt4Display import qtViewer3d
+from colWebBeamWebConnectivity import ColWebBeamWeb
+from colFlangeBeamWebConnectivity import ColFlangeBeamWeb
+from OCC import IGESControl
+
+from filletweld import FilletWeld
+
+
+class MainController(QtGui.QMainWindow):
+
+ def __init__(self):
+ QtGui.QMainWindow.__init__(self)
+ self.ui = Ui_MainWindow()
+ self.ui.setupUi(self)
+
+
+ self.gradeType ={'Please Select Type':'',
+ 'HSFG': [8.8,10.8],
+ 'Black Bolt':[3.6,4.6,4.8,5.6,5.8,6.8,9.8,12.9]}
+ self.ui.comboType.addItems(self.gradeType.keys())
+ self.ui.comboType.currentIndexChanged[str].connect(self.combotype_currentindexchanged)
+ self.ui.comboType.setCurrentIndex(0)
+
+ self.ui.comboConnLoc.currentIndexChanged[str].connect(self.setimage_connection)
+
+
+ self.ui.btn_Reset.clicked.connect(self.resetbtn_clicked)
+
+ self.ui.btn_Design.clicked.connect(self.design_btnclicked)
+ self.ui.btnInput.clicked.connect(lambda: self.dockbtn_clicked(self.ui.inputDock))
+ self.ui.btnOutput.clicked.connect(lambda: self.dockbtn_clicked(self.ui.outputDock))
+ self.ui.btn_front.clicked.connect(self.call_Frontview)
+ self.ui.btn_top.clicked.connect(self.call_Topview)
+ self.ui.btn_side.clicked.connect(self.call_Sideview)
+
+ self.ui.btn3D.clicked.connect(self.call_3DModel)
+ self.ui.chkBxBeam.clicked.connect(self.call_3DBeam)
+ self.ui.chkBxCol.clicked.connect(self.call_3DColumn)
+ self.ui.chkBxFinplate.clicked.connect(self.call_3DFinplate)
+
+ validator = QtGui.QIntValidator()
+ self.ui.txtFu.setValidator(validator)
+ self.ui.txtFy.setValidator(validator)
+
+ dbl_validator = QtGui.QDoubleValidator()
+ self.ui.txtPlateLen.setValidator(dbl_validator)
+ self.ui.txtPlateLen.setMaxLength(7)
+ self.ui.txtPlateWidth.setValidator(dbl_validator)
+ self.ui.txtPlateWidth.setMaxLength(7)
+ self.ui.txtShear.setValidator(dbl_validator)
+ self.ui.txtShear.setMaxLength(7)
+
+ minfuVal = 290
+ maxfuVal = 590
+ self.ui.txtFu.editingFinished.connect(lambda: self.check_range(self.ui.txtFu,self.ui.lbl_fu, minfuVal, maxfuVal))
+
+ minfyVal = 165
+ maxfyVal = 450
+ self.ui.txtFy.editingFinished.connect(lambda: self.check_range(self.ui.txtFy,self.ui.lbl_fy, minfyVal, maxfyVal))
+
+ self.ui.combo_Beam.addItems(get_beamcombolist())
+ self.ui.comboColSec.addItems(get_columncombolist())
+ self.ui.menuView.addAction(self.ui.inputDock.toggleViewAction())
+ self.ui.menuView.addAction(self.ui.outputDock.toggleViewAction())
+ self.ui.btn_CreateDesign.clicked.connect(self.save_design)
+ #self.ui.btn_Saveoutput.clicked.connect(self.save_design)
+ self.ui.btn_SaveMessages.clicked.connect(self.save_log)
+ #self.ui.btn_Savelog.clicked.connect(self.save_log)
+
+
+ # Saving and Restoring the finPlate window state.
+ self.retrieve_prevstate()
+
+ # Initialising the qtviewer
+ self.display,_ = self.init_display(backend_str="pyqt4")
+
+ self.ui.btnSvgSave.clicked.connect(self.save3DtoIGES)
+ #self.ui.btnSvgSave.clicked.connect(lambda:self.saveTopng(self.display))
+
+
+ def saveTopng(self,display):
+ display.ExportToImage('/home/Pictures/cad.png')
+
+ def retrieve_prevstate(self):
+ uiObj = self.get_prevstate()
+ if(uiObj != None):
+
+ self.ui.combo_Beam.setCurrentIndex(self.ui.combo_Beam.findText(uiObj['Member']['beamSection']))
+ self.ui.comboColSec.setCurrentIndex(self.ui.comboColSec.findText(uiObj['Member']['columSection']))
+
+ self.ui.txtFu.setText(str(uiObj['Member']['fu(MPa)']))
+ self.ui.txtFy.setText(str(uiObj['Member']['fy(MPa)']))
+
+ self.ui.comboConnLoc.setCurrentIndex(self.ui.comboConnLoc.findText(str(uiObj['Member']['connectivity'])))
+
+ self.ui.txtShear.setText(str(uiObj['Load']['shearForce(kN)']))
+
+ self.ui.comboDaimeter.setCurrentIndex(self.ui.comboDaimeter.findText(str(uiObj['Bolt']['diameter(mm)'])))
+ comboTypeIndex = self.ui.comboType.findText(str(uiObj['Bolt']['type']))
+ self.ui.comboType.setCurrentIndex(comboTypeIndex)
+ self.combotype_currentindexchanged(str(uiObj['Bolt']['type']))
+
+ prevValue = str(uiObj['Bolt']['grade'])
+
+ comboGradeIndex = self.ui.comboGrade.findText(prevValue)
+
+ self.ui.comboGrade.setCurrentIndex(comboGradeIndex)
+
+ #self.ui.comboDaimeter.currentText(str(uiObj['Bolt']['diameter(mm)']))
+ #self.ui.comboType.currentText(str(uiObj['Bolt']['diameter(mm)']))
+ #self.ui.comboGrade.currentText(str(uiObj['Bolt']['grade']))
+
+ self.ui.comboPlateThick_2.setCurrentIndex(self.ui.comboPlateThick_2.findText(str(uiObj['Plate']['thickness(mm)'])))
+ #self.ui.comboPlateThick_2.currentText(str(uiObj['Plate']['thickness(mm)']))
+ self.ui.txtPlateLen.setText(str(uiObj['Plate']['length(mm)']))
+ self.ui.txtPlateWidth.setText(str(uiObj['Plate']['width(mm)']))
+
+ self.ui.comboWldSize.setCurrentIndex(self.ui.comboWldSize.findText(str(uiObj['Weld']['size(mm)'])))
+ #self.ui.comboWldSize.currentText(str(uiObj['Weld']['size(mm)']))
+ #else:
+ # self.btnreset_clicked()
+
+ def setimage_connection(self):
+ '''
+ Setting image to connctivity.
+ '''
+ self.ui.lbl_connectivity.show()
+ loc = self.ui.comboConnLoc.currentText()
+ if loc == "Column flange-Beam web":
+
+ pixmap = QtGui.QPixmap(":/newPrefix/images/beam2.jpg")
+ pixmap.scaledToHeight(50)
+ pixmap.scaledToWidth(60)
+ self.ui.lbl_connectivity.setPixmap(pixmap)
+ #self.ui.lbl_connectivity.show()
+ elif(loc == "Column web-Beam web"):
+ picmap = QtGui.QPixmap(":/newPrefix/images/beam.jpg")
+ picmap.scaledToHeight(50)
+ picmap.scaledToWidth(60)
+ self.ui.lbl_connectivity.setPixmap(picmap)
+ else:
+ self.ui.lbl_connectivity.hide()
+
+
+ def getuser_inputs(self):
+ '''(nothing) -> Dictionary
+
+ Returns the dictionary object with the user input fields for designing fin plate connection
+
+ '''
+ uiObj = {}
+ uiObj["Bolt"] = {}
+ uiObj["Bolt"]["diameter(mm)"] = self.ui.comboDaimeter.currentText().toInt()[0]
+ uiObj["Bolt"]["grade"] = float(self.ui.comboGrade.currentText())
+ uiObj["Bolt"]["type"] = str(self.ui.comboType.currentText())
+
+
+ uiObj["Weld"] = {}
+ uiObj["Weld"]['size(mm)'] = self.ui.comboWldSize.currentText().toInt()[0]
+
+ uiObj['Member'] = {}
+ uiObj['Member']['beamSection'] = str(self.ui.combo_Beam.currentText())
+ uiObj['Member']['columSection'] = str(self.ui.comboColSec.currentText())
+ uiObj['Member']['connectivity'] = str(self.ui.comboConnLoc.currentText())
+ uiObj['Member']['fu(MPa)'] = self.ui.txtFu.text().toInt()[0]
+ uiObj['Member']['fy(MPa)'] = self.ui.txtFy.text().toInt()[0]
+
+ uiObj['Plate'] = {}
+ uiObj['Plate']['thickness(mm)'] = self.ui.comboPlateThick_2.currentText().toInt()[0]
+ uiObj['Plate']['height(mm)'] = self.ui.txtPlateLen.text().toInt()[0] # changes the label length to height
+ uiObj['Plate']['width(mm)'] = self.ui.txtPlateWidth.text().toInt()[0]
+
+ uiObj['Load'] = {}
+ uiObj['Load']['shearForce(kN)'] = self.ui.txtShear.text().toInt()[0]
+
+
+ return uiObj
+
+ def save_inputs(self,uiObj):
+
+ '''(Dictionary)--> None
+
+ '''
+ inputFile = QtCore.QFile('saveINPUT.txt')
+ if not inputFile.open(QtCore.QFile.WriteOnly | QtCore.QFile.Text):
+ QtGui.QMessageBox.warning(self, "Application",
+ "Cannot write file %s:\n%s." % (inputFile, file.errorString()))
+ #yaml.dump(uiObj, inputFile,allow_unicode=True, default_flow_style = False)
+ pickle.dump(uiObj, inputFile)
+
+
+ def get_prevstate(self):
+ '''
+ '''
+ fileName = 'saveINPUT.txt'
+
+ if os.path.isfile(fileName):
+ fileObject = open(fileName,'r')
+ uiObj = pickle.load(fileObject)
+ return uiObj
+ else:
+ return None
+
+
+ def outputdict(self):
+
+ ''' Returns the output of design in dictionary object.
+ '''
+ outObj = {}
+ outObj['Plate'] ={}
+ #outObj['Plate']["Thickness(mm)"] = float(self.ui.txtPlateThick.text())
+ outObj['Plate']["External Moment(kNm)"] = float(self.ui.txtExtMomnt.text())
+ outObj['Plate']["Moment Capacity(kNm)"] = float(self.ui.txtMomntCapacity.text())
+
+ outObj['Weld'] ={}
+ #outObj['Weld']["Weld Thickness(mm)"] = float(self.ui.txtWeldThick.text())
+ outObj['Weld']["Resultant Shear(kN/mm)"] = float(self.ui.txtResltShr.text())
+ outObj['Weld']["Weld Strength(kN/mm)"] = float(self.ui.txtWeldStrng.text())
+
+ outObj['Bolt'] = {}
+ outObj['Bolt']["Shear Capacity(kN)"] = float(self.ui.txtShrCapacity.text())
+ outObj['Bolt']["Bearing Capacity(kN)"] = float(self.ui.txtbearCapacity.text())
+ outObj['Bolt']["Capacity Of Bolt(kN)"] = float(self.ui.txtBoltCapacity.text())
+ outObj['Bolt']["No Of Bolts"] = float(self.ui.txtNoBolts.text())
+ outObj['Bolt']["No.Of Row"] = int(self.ui.txt_row.text())
+ outObj['Bolt']["No.Of Column"] = int(self.ui.txt_col.text())
+ outObj['Bolt']["Pitch Distance(mm)"] = float(self.ui.txtPitch.text())
+ outObj['Bolt']["Guage Distance(mm)"] = float(self.ui.txtGuage.text())
+ outObj['Bolt']["End Distance(mm)"]= float(self.ui.txtEndDist.text())
+ outObj['Bolt']["Edge Distance(mm)"]= float(self.ui.txtEdgeDist.text())
+
+ return outObj
+
+
+ def save_design(self):
+ self.outdict = self.outputdict()
+ self.inputdict = self.getuser_inputs()
+ self.save_yaml(self.outdict,self.inputdict)
+
+ #self.save(self.outdict,self.inputdict)
+
+ def save_log(self):
+
+ fileName,pat =QtGui.QFileDialog.getSaveFileNameAndFilter(self,"Save File As","/home/deepa/SaveMessages","Text files (*.txt)")
+ return self.save_file(fileName+".txt")
+
+ def save_file(self, fileName):
+ '''(file open for writing)-> boolean
+ '''
+ fname = QtCore.QFile(fileName)
+ if not fname.open(QtCore.QFile.WriteOnly | QtCore.QFile.Text):
+ QtGui.QMessageBox.warning(self, "Application",
+ "Cannot write file %s:\n%s." % (fileName, fname.errorString()))
+ return False
+
+ outf = QtCore.QTextStream(fname)
+ QtGui.QApplication.setOverrideCursor(QtCore.Qt.WaitCursor)
+ outf << self.ui.textEdit.toPlainText()
+ QtGui.QApplication.restoreOverrideCursor()
+
+ #self.setCurrentFile(fileName);
+ QtGui.QMessageBox.about(self,'Information',"File saved")
+ return True
+
+
+ def save_yaml(self,outObj,uiObj):
+ '''(dictiionary,dictionary) -> NoneType
+ Saving input and output to file in following format.
+ Bolt:
+ diameter: 6
+ grade: 8.800000190734863
+ type: HSFG
+ Load:
+ shearForce: 100
+
+ '''
+ newDict = {"INPUT": uiObj, "OUTPUT": outObj}
+ fileName = QtGui.QFileDialog.getSaveFileName(self,"Save File As","/home/deepa/SaveDesign","Text File (*.txt)")
+ f = open(fileName,'w')
+ yaml.dump(newDict,f,allow_unicode=True, default_flow_style=False)
+ return self.save_file(fileName+".txt")
+
+
+ def resetbtn_clicked(self):
+ '''(NoneType) -> NoneType
+
+ Resets all fields in input as well as output window
+
+ '''
+ # user Inputs
+ self.ui.combo_Beam.setCurrentIndex((0))
+ self.ui.comboColSec.setCurrentIndex((0))
+ self.ui.comboConnLoc.setCurrentIndex((0))
+ self.ui.txtFu.clear()
+ self.ui.txtFy.clear()
+
+ self.ui.txtShear.clear()
+
+ self.ui.comboDaimeter.setCurrentIndex(0)
+ self.ui.comboType.setCurrentIndex((0))
+ self.ui.comboGrade.setCurrentIndex((0))
+
+ self.ui.comboPlateThick_2.setCurrentIndex((0))
+ self.ui.txtPlateLen.clear()
+ self.ui.txtPlateWidth.clear()
+
+ self.ui.comboWldSize.setCurrentIndex((0))
+
+ #----Output
+ self.ui.txtShrCapacity.clear()
+ self.ui.txtbearCapacity.clear()
+ self.ui.txtBoltCapacity.clear()
+ self.ui.txtNoBolts.clear()
+ self.ui.txtboltgrpcapacity.clear()
+ self.ui.txt_row.clear()
+ self.ui.txt_col.clear()
+ self.ui.txtPitch.clear()
+ self.ui.txtGuage.clear()
+ self.ui.txtEndDist.clear()
+ self.ui.txtEdgeDist.clear()
+
+ #self.ui.txtPlateThick.clear()
+ self.ui.txtplate_ht.clear()
+ self.ui.txtplate_width.clear()
+ self.ui.txtExtMomnt.clear()
+ self.ui.txtMomntCapacity.clear()
+
+ #self.ui.txtWeldThick.clear()
+ self.ui.txtResltShr.clear()
+ self.ui.txtWeldStrng.clear()
+ self.ui.textEdit.clear()
+
+ def dockbtn_clicked(self,widget):
+
+ '''(QWidget) -> NoneType
+
+ This method dock and undock widget(QdockWidget)
+ '''
+
+ flag = widget.isHidden()
+ if(flag):
+
+ widget.show()
+ else:
+ widget.hide()
+
+ def combotype_currentindexchanged(self,index):
+
+ '''(Number) -> NoneType
+ '''
+ items = self.gradeType[str(index)]
+
+ self.ui.comboGrade.clear()
+ strItems = []
+ for val in items:
+ strItems.append(str(val))
+
+ self.ui.comboGrade.addItems(strItems)
+
+
+ def check_range(self, widget,lblwidget, minVal, maxVal):
+
+ '''(QlineEdit,QLable,Number,Number)---> NoneType
+ Validating F_u(ultimate Strength) and F_y (Yeild Strength) textfields
+ '''
+ textStr = widget.text()
+ val = int(textStr)
+ if( val < minVal or val > maxVal):
+ QtGui.QMessageBox.about(self,'Error','Please Enter a value between %s-%s' %(minVal, maxVal))
+ widget.clear()
+ widget.setFocus()
+ palette = QtGui.QPalette()
+ palette.setColor(QtGui.QPalette.Foreground,QtCore.Qt.red)
+ lblwidget.setPalette(palette)
+ else:
+ palette = QtGui.QPalette()
+ lblwidget.setPalette(palette)
+
+ def display_output(self, resultObj):
+
+ '''(dictionary) --> NoneType
+
+ Setting design result values to the respective textboxes in the output window
+
+ '''
+ # resultObj['Bolt']
+ shear_capacity = resultObj['Bolt']['shearcapacity']
+ self.ui.txtShrCapacity.setText(str(shear_capacity))
+
+ bearing_capacity = resultObj['Bolt']['bearingcapacity']
+ self.ui.txtbearCapacity.setText(str(bearing_capacity))
+
+ bolt_capacity = resultObj['Bolt']['boltcapacity']
+ self.ui.txtBoltCapacity.setText(str(bolt_capacity))
+
+ no_ofbolts = resultObj['Bolt']['numofbolts']
+ self.ui.txtNoBolts.setText(str(no_ofbolts))
+ #newly added field
+ boltGrp_capacity = resultObj['Bolt']['boltgrpcapacity']
+ self.ui.txtboltgrpcapacity.setText(str(boltGrp_capacity))
+
+ no_ofrows = resultObj['Bolt']['numofrow']
+ self.ui.txt_row.setText(str(no_ofrows))
+
+ no_ofcol = resultObj['Bolt']['numofcol']
+ self.ui.txt_col.setText(str(no_ofcol))
+
+ pitch_dist = resultObj['Bolt']['pitch']
+ self.ui.txtPitch.setText(str(pitch_dist))
+
+ gauge_dist = resultObj['Bolt']['gauge']
+ self.ui.txtGuage.setText(str(gauge_dist))
+
+ end_dist = resultObj['Bolt']['enddist']
+ self.ui.txtEndDist.setText(str(end_dist))
+
+ edge_dist = resultObj['Bolt']['edge']
+ self.ui.txtEdgeDist.setText(str(edge_dist))
+
+ # resultObj['Weld']
+ # weld_thickness = resultObj['Weld']['thickness']
+ # self.ui.txtWeldThick.setText(str(weld_thickness))
+
+ resultant_shear = resultObj['Weld']['resultantshear']
+ self.ui.txtResltShr.setText(str(resultant_shear))
+
+ weld_strength = resultObj['Weld']['weldstrength']
+ self.ui.txtWeldStrng.setText(str(weld_strength))
+
+
+ # Newly included fields
+ plate_ht = resultObj['Plate']['height']
+ self.ui.txtplate_ht.setText(str(plate_ht))
+
+ plate_width = resultObj['Plate']['width']
+ self.ui.txtplate_width.setText(str(plate_width))
+
+ moment_demand = resultObj['Plate']['externalmoment']
+ self.ui.txtExtMomnt.setText(str(moment_demand))
+
+ moment_capacity = resultObj['Plate']['momentcapacity']
+ self.ui.txtMomntCapacity.setText(str(moment_capacity))
+
+
+ def displaylog_totextedit(self):
+ '''
+ This method displaying Design messages(log messages)to textedit widget.
+ '''
+
+ afile = QtCore.QFile('fin.log')
+
+ if not afile.open(QtCore.QIODevice.ReadOnly):
+ QtGui.QMessageBox.information(None, 'info', afile.errorString())
+
+ stream = QtCore.QTextStream(afile)
+ self.ui.textEdit.setHtml(stream.readAll())
+
+ def get_backend(self):
+ """
+ loads a backend
+ backends are loaded in order of preference
+ since python comes with Tk included, but that PySide or PyQt4
+ is much preferred
+ """
+ try:
+ from PySide import QtCore, QtGui
+ return 'pyside'
+ except:
+ pass
+ try:
+ from PyQt4 import QtCore, QtGui
+ return 'pyqt4'
+ except:
+ pass
+ # Check wxPython
+ try:
+ import wx
+ return 'wx'
+ except:
+ raise ImportError("No compliant GUI library found. You must have either PySide, PyQt4 or wxPython installed.")
+ sys.exit(1)
+
+ # QtViewer
+ def init_display(self,backend_str=None, size=(1024, 768)):
+
+ global display, start_display, app, _, USED_BACKEND
+
+ if not backend_str:
+ USED_BACKEND = self.get_backend()
+ elif backend_str in [ 'pyside', 'pyqt4']:
+ USED_BACKEND = backend_str
+ else:
+ raise ValueError("You should pass either 'qt' or 'tkinter' to the init_display function.")
+ sys.exit(1)
+
+ # Qt based simple GUI
+ if USED_BACKEND in ['pyqt4', 'pyside']:
+ if USED_BACKEND == 'pyqt4':
+ from PyQt4 import QtCore, QtGui, QtOpenGL
+ from OCC.Display.pyqt4Display import qtViewer3d
+ elif USED_BACKEND == 'pyside':
+ from PySide import QtCore, QtGui, QtOpenGL
+ from OCC.Display.pysideDisplay import qtViewer3d
+
+ self.ui.modelTab = qtViewer3d(self)
+ #self.ui.model2dTab = qtViewer3d(self)
+ self.setWindowTitle("Osdag-%s 3d viewer ('%s' backend)" % (VERSION, USED_BACKEND))
+ self.ui.mytabWidget.resize(size[0], size[1])
+ self.ui.mytabWidget.addTab(self.ui.modelTab,"3D")
+ #self.ui.mytabWidget.addTab(self.ui.model2dTab, "2D")
+
+ #self.ui.mytabWidget.setCentralWidget(self.ui.modelTab)
+ #self.ui.mytabWidget.centerOnScreen()
+
+ self.ui.modelTab.InitDriver()
+ display = self.ui.modelTab._display
+ #display_2d = self.ui.model2dTab._display
+
+ # background gradient
+ display.set_bg_gradient_color(23,1,32,23,1,32)
+ #display_2d.set_bg_gradient_color(255,255,255,255,255,255)
+ # display black trihedron
+ display.display_trihedron()
+ display.View.SetProj(1, 1, 1)
+ def centerOnScreen(self):
+ '''Centers the window on the screen.'''
+ resolution = QtGui.QDesktopWidget().screenGeometry()
+ self.move((resolution.width() / 2) - (self.frameSize().width() / 2),
+ (resolution.height() / 2) - (self.frameSize().height() / 2))
+ def start_display():
+
+ self.ui.modelTab.raise_() # make the application float to the top
+
+ return display, start_display
+
+ def display3Dmodel(self,cadlist,component):
+
+ if component == "Column":
+ self.display.EraseAll()
+ osdagDisplayShape(self.display, cadlist[0], update=True)
+ elif component == "Beam":
+ display.EraseAll()
+ osdagDisplayShape(self.display, cadlist[1],material = Graphic3d_NOT_2D_ALUMINUM, update=True)
+ elif component == "Finplate" :
+ display.EraseAll()
+ osdagDisplayShape(self.display,cadlist[2],color = 'red', update = True)
+ osdagDisplayShape(self.display, cadlist[3], color = 'blue', update = True)
+ self.display.DisplayShape(cadlist[4],color = Quantity_NOC_SADDLEBROWN, update=True)
+ self.display.DisplayShape(cadlist[5],color = Quantity_NOC_SADDLEBROWN, update = True)
+ elif component == "Model":
+ osdagDisplayShape(self.display, cadlist[0], update=True)
+ osdagDisplayShape(self.display, cadlist[1],material = Graphic3d_NOT_2D_ALUMINUM, update=True)
+ osdagDisplayShape(self.display,cadlist[2],color = 'red', update = True)
+ osdagDisplayShape(self.display,cadlist[3],color = 'red', update = True)
+ osdagDisplayShape(self.display, cadlist[4], color = 'blue', update = True)
+ self.display.DisplayShape(cadlist[5],color = Quantity_NOC_SADDLEBROWN, update=True)
+ self.display.DisplayShape(cadlist[6],color = Quantity_NOC_SADDLEBROWN, update = True)
+ else:
+ pass
+
+ start_display()
+
+
+ def create3DColWebBeamWeb(self):
+ '''
+ creating 3d cad model with column web beam web
+ '''
+
+ column = ISection(B = 83, T = 14.1, D = 250, t = 11, R1 = 12, R2 = 3.2, alpha = 98, length = 1000)
+ beam = ISection(B = 140, T = 16,D = 400,t = 8.9, R1 = 14, R2 = 7, alpha = 98,length = 500)
+ Fweld1 = FilletWeld(L= 300,b = 6, h = 6)
+ #Fweld1 = Weld(L= 300,W = beam.t, T = 8)
+
+ plate = Plate(L= 300,W =100, T = 10)
+ boltRadius = 10
+ nutRadius = 10
+
+ colwebconn = ColWebBeamWeb(column,beam,Fweld1,plate,boltRadius,nutRadius)
+ return colwebconn.create_3dmodel()
+
+ def createColFlangeBeamWeb(self):
+ '''
+ Creating 3d cad model with column flange beam web connection
+ '''
+ column = ISection(B = 83, T = 14.1, D = 250, t = 11, R1 = 12, R2 = 3.2, alpha = 98, length = 1000)
+ beam = ISection(B = 140, T = 16,D = 400,t = 8.9, R1 = 14, R2 = 7, alpha = 98,length = 500)
+ weld = Weld(L= 300,b = 6.0, T = 8)
+ plate = Plate(L= weld.L,W =100, T = 10)
+ boltRadius = 10
+ nutRadius = 10
+
+ colflangeconn = ColFlangeBeamWeb(column,beam,weld,plate,boltRadius,nutRadius)
+ return colflangeconn.create_3dmodel()
+
+ def call_3DModel(self):
+ if self.ui.btn3D.isEnabled():
+ self.ui.chkBxBeam.setChecked(QtCore.Qt.Unchecked)
+ self.ui.chkBxCol.setChecked(QtCore.Qt.Unchecked)
+ self.ui.chkBxFinplate.setChecked(QtCore.Qt.Unchecked)
+ self.ui.mytabWidget.setCurrentIndex(0)
+
+ if self.ui.comboConnLoc.currentText()== "Column web-Beam web":
+ memberlist = self.create3DColWebBeamWeb()
+ else:
+ self.ui.mytabWidget.setCurrentIndex(0)
+ memberlist = self.createColFlangeBeamWeb()
+
+ #memberlist = self.create_3dmodel()
+ #self.ui.btn3D.setStyleSheet("background-color: red")
+ self.display3Dmodel(memberlist, "Model")
+
+
+ def call_3DBeam(self):
+ '''
+ Creating and displaying 3D Beam
+ '''
+ memberlist = self.create3DColWebBeamWeb()
+
+ if self.ui.chkBxBeam.isChecked():
+ self.ui.chkBxCol.setChecked(QtCore.Qt.Unchecked)
+ self.ui.chkBxFinplate.setChecked(QtCore.Qt.Unchecked)
+ self.ui.mytabWidget.setCurrentIndex(0)
+ self.display3Dmodel(memberlist, "Beam")
+ #self.ui.chkBxBeam.setChecked(QtCore.Qt.Unchecked)
+
+ def call_3DColumn(self):
+ memberlist = self.create3DColWebBeamWeb()
+ if self.ui.chkBxCol.isChecked():
+ self.ui.chkBxBeam.setChecked(QtCore.Qt.Unchecked)
+ self.ui.chkBxFinplate.setChecked(QtCore.Qt.Unchecked)
+ self.ui.mytabWidget.setCurrentIndex(0)
+ self.display3Dmodel(memberlist, "Column")
+ #self.ui.chkBxBeam.setChecked(QtCore.Qt.Unchecked
+
+ def call_3DFinplate(self):
+ memberlist = self.create3DColWebBeamWeb()
+ if self.ui.chkBxFinplate.isChecked():
+ self.ui.chkBxBeam.setChecked(QtCore.Qt.Unchecked)
+ self.ui.chkBxCol.setChecked(QtCore.Qt.Unchecked)
+ self.ui.mytabWidget.setCurrentIndex(0)
+ self.display3Dmodel(memberlist, "Finplate")
+ #self.ui.chkBxBeam.setChecked(QtCore.Qt.Unchecked
+
+ def design_btnclicked(self):
+
+ # Getting User Inputs.
+ uiObj = self.getuser_inputs()
+ print uiObj
+
+ # FinPlate Design Calculations.
+ resultObj = finConn(uiObj)
+
+ # Displaying Design Calculations To Output Window
+ self.display_output(resultObj)
+
+ # Displaying Messages related to FinPlate Design.
+ self.ui.textEdit.clear()
+ self.displaylog_totextedit()
+
+
+ def close_event(self, event):
+ '''
+ Closing finPlate window.
+ '''
+ uiInput = self.getuser_inputs()
+ self.save_inputs(uiInput)
+ reply = QtGui.QMessageBox.question(self, 'Message',
+ "Are you sure to quit?", QtGui.QMessageBox.Yes, QtGui.QMessageBox.No)
+
+ if reply == QtGui.QMessageBox.Yes:
+ event.accept()
+ else:
+ event.ignore()
+
+
+ def create2Dcad(self):
+
+
+ # ISection COLUMN
+ origin1 = numpy.array([0, 0, 0])
+ uDir1 = numpy.array([1.0, 0, 0])
+ wDir1 = numpy.array([0.0, 0, 1.0])
+ t = 8.9
+ weldThick = 8
+ iSection1 = ISection(B = 83, T = 14.1, D = 250, t = 11, R1 = 12, R2 = 3.2, alpha = 98, length = 1000)
+ iSection1.place(origin1, uDir1, wDir1)
+
+ # ISection BEAM
+ uDir2 = numpy.array([0, 1.0, 0])
+ wDir2 = numpy.array([1.0, 0, 0.0])
+ d = t/2.0 + weldThick
+ origin2 = numpy.array([0, 0, 500]) + (d+7.55) * wDir2
+ iSection2 = ISection(B = 140, T = 16,D = 400,t = 8.9, R1 = 14, R2 = 7, alpha = 98,length = 400)
+ iSection2.place(origin2, uDir2, wDir2)
+
+ # WELD
+ weld = Weld(L= 300,W =iSection2.t, T = 8)
+ #plateThickness = 10
+ uDir3 = numpy.array([0, 1.0, 0])
+ wDir3 = numpy.array([1.0, 0, 0.0])
+ origin3 = (iSection1.secOrigin +
+ iSection1.t/2.0 * iSection1.uDir +
+ iSection1.length/2.0 * iSection1.wDir +
+ iSection2.t/2.0 * (-iSection2.uDir)+
+ weld.W/2.0 * (-iSection2.uDir))
+ #origin3 = numpy.array([0, 0, 500]) + t/2.0 *wDir3 + plateThickness/2.0 * (-iSection2.uDir)
+ weld.place(origin3, uDir3, wDir3)
+
+ # PLATE
+ plate = Plate(L= weld.L,W =100, T = 10)
+ uDir4 = numpy.array([0, 1.0, 0])
+ wDir4 = numpy.array([1.0, 0, 0.0])
+ origin4 = weld.secOrigin + weld.T * weld.wDir
+ plate.place(origin4, uDir4, wDir4)
+
+ # BOLT BODY
+ bolt_T = 6.0
+ origin51 = (plate.secOrigin + (-
+ plate.T/2.0 - bolt_T) * plate.uDir +
+ plate.W/2.0 * plate.wDir)
+
+ uDir5 = plate.wDir
+ wDir5 = plate.uDir
+ ## Bolt1
+ bolt1 = Bolt(R = 10.0,T = bolt_T, H = 30.0, r = 4.0 )
+ bolt1.place(origin51, uDir5, wDir5)
+
+ ## Bolt2
+ bolt2 = Bolt(R = 10.0,T = bolt_T, H = 30.0, r = 4.0 )
+ origin52 = origin51 + 50 *plate.vDir
+ bolt2.place(origin52, uDir5, wDir5)
+
+ ## Bolt3
+ bolt3 = Bolt(R = 10.0,T = bolt_T, H = 30.0, r = 4.0 )
+ origin53 = origin51 - 50*plate.vDir
+ bolt3.place(origin53, uDir5, wDir5)
+ bolt_list =[bolt1,bolt2,bolt3]
+
+ # NUTBODY
+ ## Nut1
+ nut1 = Nut(R = 10.0,T = 10.0, H = 6.1, innerR1 = 6.0, outerR2 = 8.3)
+ uDir = uDir5
+ wDir = wDir5
+ nut_Origin1 = origin51 + (bolt1.T/2 * plate.uDir)+(plate.T *plate.uDir)+ (iSection2.T/2 * plate.uDir)
+ nut1.place(nut_Origin1, uDir, wDir)
+
+ ## Nut2
+ nut2 = Nut(R = 10.0,T = 10.0, H = 6.1, innerR1 = 6.0, outerR2 = 8.3)
+ nut_Origin2 = origin52 + (bolt1.T/2 * plate.uDir)+(plate.T *plate.uDir)+ (iSection2.T/2 * plate.uDir)
+ nut2.place(nut_Origin2, uDir, wDir)
+
+ ## Nut3
+ nut3 =Nut(R = 10.0,T = 10.0, H = 6.1, innerR1 = 6.0, outerR2 = 8.3)
+ nut_Origin3 = origin53 + (bolt1.T/2 * plate.uDir)+(plate.T *plate.uDir)+ (iSection2.T/2 * plate.uDir)
+ nut3.place(nut_Origin3, uDir5, wDir5)
+ nut_list = [nut1,nut2,nut3]
+
+ # Call for createModel
+ iSectionModel1 = iSection1.createModel()
+ iSectionModel2 = iSection2.createModel()
+ weldModel = weld.createModel()
+ plateModel = plate.createModel()
+ boltModels = []
+ for bolt in bolt_list:
+
+ boltModels.append(bolt.createModel())
+
+ #color = Quantity_NOC_SADDLEBROWN,
+ nutModels = []
+ for nut in nut_list:
+ nutModels.append(nut.createModel())
+
+ isection = BRepAlgoAPI_Fuse(iSectionModel1,iSectionModel2).Shape()
+ weld_isection = BRepAlgoAPI_Fuse(isection,weldModel).Shape()
+ plate_weld = BRepAlgoAPI_Fuse(weld_isection,plateModel).Shape()
+
+ plate_weld_bolt = plate_weld
+ for bolt in boltModels:
+ plate_weld_bolt = BRepAlgoAPI_Fuse(plate_weld_bolt, bolt).Shape()
+
+
+ final_model = plate_weld_bolt
+ for nt in nutModels:
+ final_model = BRepAlgoAPI_Fuse(final_model,nt).Shape()
+ return final_model
+
+ # Export to IGES
+ def save3DtoIGES(self):
+ shape = self.create2Dcad()
+ i = IGESControl.IGESControl_Controller()
+ i.Init()
+ iges_writer = IGESControl.IGESControl_Writer()
+ iges_writer.AddShape(shape)
+ iges_writer.Write('/home/deepa/Pictures/osdag.iges')
+
+ def display2DModel(self, final_model, viewName):
+
+ #display, start_display, _, _ = self.simpleGUI()
+
+ self.display.set_bg_gradient_color(255, 255, 255, 255, 255, 255)
+ # Get Context
+ ais_context = self.display.GetContext().GetObject()
+
+ # Get Prs3d_drawer from previous context
+ drawer_handle = ais_context.DefaultDrawer()
+ drawer = drawer_handle.GetObject()
+ drawer.EnableDrawHiddenLine()
+
+ hla = drawer.HiddenLineAspect().GetObject()
+ hla.SetWidth(2)
+ hla.SetColor(Quantity_NOC_RED)
+
+ # increase line width in the current viewer
+ # This is only viewed in the HLR mode (hit 'e' key for instance)
+
+ line_aspect = drawer.SeenLineAspect().GetObject()
+ line_aspect.SetWidth(2.8)
+ line_aspect.SetColor(Quantity_NOC_BLUE1)
+
+ self.display.DisplayShape(final_model, update = True)
+
+ self.display.SetModeHLR()
+ self.display.FitAll()
+
+ if (viewName == "Front"):
+ display.View_Front()
+ elif (viewName == "Top"):
+ display.View_Top()
+ elif (viewName == "Right"):
+ display.View_Right()
+ else:
+ pass
+
+ start_display()
+
+ def call_Frontview(self):
+
+ '''Displays front view of 2Dmodel
+ '''
+ self.ui.mytabWidget.setCurrentIndex(1)
+ final_model = self.create2Dcad()
+ self.display2DModel(final_model, "Front")
+
+ def call_Topview(self):
+
+ '''Displays Top view of 2Dmodel
+ '''
+ final_model = self.create2Dcad()
+ self.display2DModel(final_model, "Top")
+
+ def call_Sideview(self):
+
+ '''Displays Side view of the 2Dmodel'
+ '''
+ final_model = self.create2Dcad()
+ self.display2DModel(final_model, "Right")
+
+def set_osdaglogger():
+
+ logger = logging.getLogger("osdag")
+ logger.setLevel(logging.DEBUG)
+
+ # create the logging file handler
+ fh = logging.FileHandler("fin.log", mode="a")
+
+ #,datefmt='%a, %d %b %Y %H:%M:%S'
+ #formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
+
+ formatter = logging.Formatter('''
+ <div class="LOG %(levelname)s">
+ <span class="DATE">%(asctime)s</span>
+ <span class="LEVEL">%(levelname)s</span>
+ <span class="MSG">%(message)s</span>
+ </div>''')
+ formatter.datefmt = '%a, %d %b %Y %H:%M:%S'
+ fh.setFormatter(formatter)
+
+ # add handler to logger object
+ logger.addHandler(fh)
+
+
+if __name__ == '__main__':
+
+ # linking css to log file to display colour logs.
+ set_osdaglogger()
+ rawLogger = logging.getLogger("raw")
+ rawLogger.setLevel(logging.INFO)
+ fh = logging.FileHandler("fin.log", mode="w")
+ formatter = logging.Formatter('''%(message)s''')
+ fh.setFormatter(formatter)
+ rawLogger.addHandler(fh)
+ rawLogger.info('''<link rel="stylesheet" type="text/css" href="log.css"/>''')
+
+
+
+ app = QtGui.QApplication(sys.argv)
+ window = MainController()
+ window.show()
+ sys.exit(app.exec_())
+
+
+
+
+