|
Description |
---|
Cette macro est une application complète, il ouvre une boîte de dialogue demandant les dimensions angulaires de votre pièce, puis crée l'objet dans le document, et, crée une page avec les vues, de dessus, de face et latérale de la pièce. |
Auteur |
Nicotuf |
Liens |
Recettes macros Comment installer une macro Comment ajouter une barre d'outils |
Version |
1.0 |
Date dernière modification |
YYYY-MM-DD |
Contents |
This macro is a complete application, it pops up a dialog asking for the dimensions of your corner piece, then creates the object in the document and creates a page view with top, front and lateral views of the piece. Original source: Macro Corner shapes wizard
Macro Corner shapes wizard/update
# Corner Shape Wizard
# http://www.freecadweb.org/wiki/index.php?title=Macro_Corner_shapes_wizard/update
# Version 10.03.2013
# Modifications: Neondata, Rainer Nase
# original source: http://www.freecadweb.org/wiki/index.php?title=Macro_Corner_shapes_wizard
# -*- coding:utf-8 -*-
#
# output to page file commented out ?
#####################################
# import external functions
#from os import *
import FreeCAD as App, FreeCADGui as Gui, Part, Draft, math, MeshPart, Mesh, Drawing
from PyQt4 import QtGui,QtCore
from FreeCAD import Base
App=FreeCAD
Gui=FreeCADGui
##################################
# Class definition
class CornerSteel:
def __init__(self, obj):
obj.addProperty("App::PropertyLength","L1","CornerSteel","Width_1").L1=20.0
obj.addProperty("App::PropertyLength","L2","CornerSteel","Width_2").L2=20.0
obj.addProperty("App::PropertyLength","e1","CornerSteel","Thickness").e1=2.0
#obj.addProperty("App::PropertyLength","e2","CornerSteel","Thickness2").e2=2.0
obj.addProperty("App::PropertyLength","Length","CornerSteel","Length").Length=200.0
obj.Proxy = self
def execute(self, fp):
P1=Base.Vector(fp.e1,fp.e1,0)
S1=Part.makeBox(fp.L1,fp.L2,fp.Length)
S2=Part.makeBox(fp.L1-fp.e1,fp.L2-fp.e1,fp.Length,P1)
fp.Shape=S1.cut(S2)
##################################
# definition of local functions :
def proceed():
QtGui.qApp.setOverrideCursor(QtCore.Qt.WaitCursor)
if App.ActiveDocument==None:
App.newDocument("CornerSteel")
oldDocumentObjects=App.ActiveDocument.Objects
try:
QL1 = float(l[0].text())
QL2 = float(l[1].text())
Qe = float(l[2].text())
QLength = float(l[3].text())
except:
App.Console.PrintError("Wrong input! Only numbers allowed...\n")
Cor=App.ActiveDocument.addObject("Part::FeaturePython","CornerSteel")
CornerSteel(Cor)
Cor.ViewObject.Proxy=0
Cor.L1 = QL1
Cor.L2 = QL2
Cor.e1 = Qe
Cor.Length=QLength
App.ActiveDocument.recompute()
Gui.SendMsgToActiveView("ViewFit")
QtGui.qApp.restoreOverrideCursor()
Drawing(Cor)
dialog.hide()
def hide():
dialog.hide()
def Drawing(obj):
ObjetProjete=obj.Shape
DimX=ObjetProjete.BoundBox.XLength
DimY=ObjetProjete.BoundBox.YLength
DimZ=ObjetProjete.BoundBox.ZLength
page = App.activeDocument().addObject('Drawing::FeaturePage','Page')
page.Template = App.getResourceDir()+'Mod/Drawing/Templates/A3_Landscape.svg'
ProfileView = App.activeDocument().addObject('Drawing::FeatureViewPart','ProfileView')
ProfileView.Source = obj
ProfileView.Direction = (0.0,0.0,1.0)
ProfileView.Scale = 1.0
ProfileView.X = 50.0
ProfileView.Y = 50.0
page.addObject(ProfileView)
LeftView = App.activeDocument().addObject('Drawing::FeatureViewPart','LeftView')
LeftView.Source = obj
LeftView.Direction = (-1.0,0.0,0.0)
LeftView.ShowHiddenLines = True
LeftView.Scale = 1.0
LeftView.Rotation = 180.0
LeftView.X = 50.0+DimX/2+DimX
LeftView.Y = 50.0
page.addObject(LeftView)
TopView = App.activeDocument().addObject('Drawing::FeatureViewPart','TopView')
TopView.Source = obj
TopView.Direction = (0.0,-1.0,0.0)
TopView.ShowHiddenLines = True
TopView.Scale = 1.0
TopView.Rotation = 180.0
TopView.X = 50.0+DimX/2+DimX
TopView.Y = 50.0+DimX/2+DimY+DimX
page.addObject(TopView)
IsoView = App.activeDocument().addObject('Drawing::FeatureViewPart','IsoView')
IsoView.Source = obj
IsoView.Direction = (-1.0,-1.0,0.5)
IsoView.Scale = 1.0
IsoView.ShowSmoothLines = True
IsoView.X = DimZ+DimX/2
IsoView.Y = 7*DimZ+3*DimY
page.addObject(IsoView)
App.activeDocument().recompute()
# PageFile = open(page.PageResult,'r')
# OutFile = open('temp.svg','w')
# OutFile.write(PageFile.read())
# del OutFile,PageFile
l = [] # Array to transfer parameters to the process
F = [ ["Width first side" , "20."] ]
F.append(["Width second side" , "10."])
F.append(["Thickness" , "3."])
F.append(["Length" , "100."])
dialog = QtGui.QDialog()
dialog.resize(200,200)
dialog.setWindowTitle("Angle profile (angle steel)")
la = QtGui.QVBoxLayout(dialog)
# adding the input fields to the GUI
for field in range(len(F)):
la.addWidget(QtGui.QLabel(F[field][0]))
l.append( QtGui.QLineEdit(F[field][1]) )
la.addWidget(l[field])
e1 = QtGui.QLabel("Dimensions of the corner profile")
commentFont=QtGui.QFont("Arial",10,True)
e1.setFont(commentFont)
la.addWidget(e1)
okbox = QtGui.QDialogButtonBox(dialog)
okbox.setOrientation(QtCore.Qt.Horizontal)
okbox.setStandardButtons(QtGui.QDialogButtonBox.Cancel|QtGui.QDialogButtonBox.Ok)
la.addWidget(okbox)
QtCore.QObject.connect(okbox, QtCore.SIGNAL("accepted()"), proceed)
QtCore.QObject.connect(okbox, QtCore.SIGNAL("rejected()"), hide)
QtCore.QMetaObject.connectSlotsByName(dialog)
dialog.show()